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NEWS 


Memory-Same Price 
4K Now Standard In 6800 

San Antonio The SwTPC 6800 computer system, always a best buy is now an 
even greater bargain. Price reductions by the manufacturers of MOS memory cir¬ 
cuits have made it possible to now offer the standard 5395,00 OHOO computer kit 
with 4K of memory instead of 2K as previously. Memory circuits are 21 LQ2 types 
which make possible powering up to 24K of memory in the slock chassis with ihe 
standard power supply, 

I lie Southwest Technical 6800 at $395,00 includes everything needed tu work 
with your terminal. You get 4K of static MOS memory and a serial interface as 
part of the basic package. These are not extra cost options (7) as in many com¬ 
puter systems on the market. 



8K MEMORY CARDS 
ANNOUNCED - 

For those 6800 systems needing the 
maximum possible amount of memory, 
Southwest Technical Products announ¬ 
ces KK memory cards. These memory 
expansion cards have KK Bytes of low 
power MOS memory per board. These 
kits feature the new 4K static RAMS 
that are now becoming available. These 
new RAMS make it possible to put KK 
of memory on a board without crowding 
the parts, or using small hard to solder 
connecting lines. These new memory 
boards feature DIP switch address selec¬ 
tion and a write protect switch on each 
board, 

flic low power consumption of this 
new memory board makes it possible to 
use up to 4KK of memory in the stand¬ 
ard 6800 chassis with the stock power 
supply. Priced at $250,00 these mem¬ 
ory cards cost no more than less dense 
memories from other sources. 


PRICES C UT ON 
4K MEMORIES 

Soutliwest Technical Products lias re¬ 
duced the price of its standard 4K mem¬ 
ory card by 20%. These cards use low 
power 211,02 static memories. The new 
price for the MP-M memory kit is 
S 100.00 for a full 4K kit. 

This kit contains 4K of memory with 
full buffering and dual on-board voltage 
regulators. Six of these memory cards 
may be used in a standard 6800 chassis 
to provide 24K of memory for the 
system. Memory now becomes even 
mo re of a b a rga in 2 4 K for or 1 1 y S600 D 0. 

Who Needs It? 

We continue to gel reports f rom custo¬ 
mers who are amazed at the ease of 
assembly of the 6800 computer. One 
reports that he purchased test equip¬ 
ment before ordering a computer at the 
advice of friends who owned brand “X” 
machines. 1 Ms total use of the test equip¬ 
ment was zero (0) when he installed 


each board in the 6800 and they all pro¬ 
ceeded to work perfectly the first lime. 
Me later found in comparing notes with 
other 6800 owners that his was not a 
unique experience. 

People who have built most of the vari¬ 
ous types of computers on the market 
generally agree that our instructions are 
the best and most complete. So don't 
worry about purchasing the least ex¬ 
pensive computer system, there are si ill 
good honest values being offered in the 
world of personal computing, 

SUPER SOFTWARE 

“Lack of Software” can no longer be 
used as an excuse by those who have the 
poor taste to purchase computers using 
older, less elegant processors than the 
MC-6800. Southwest Technical Products 
has not only editor-assembler and game 
programs available for the 6800. but also 
both 4K and 8K BASIC. 

The ability to run ANSI! standard 
BASIC programs on the 6800 make the 
enormous number of BASIC programs 
out there all usable on the SwTPC 6800, 
Thai's right, you can run anymies BASIC' 
programs on the 6800 provided they are 
written in standard BASIC (as most are), 
4K Basic at $4.4$ and KK BASIC at 
$9.95 ate inexpensive enough for any¬ 
one to own. They do not cost hundreds 
of dollars as in some systems, or only 
become available when combined with 
purchase of huge amounts of memory as 
in others. 

Loading even a relatively long program 
such as 8K BASIC into your SwTPC 
6800 is not a long procedure when the 
AC-30 cassette interface is used. This 
super reliable and inexpensive ($79.95 
complete with cabinet and power supply) 
cassette interface uses the “Kansas City” 
standard format and will load KK BASIC 
in approximately five minutes. 



SOUTHWEST TECHNICAL PRODUCTS CORPORATION 

219 W. Rhapsody 

San Antonio, Texas 78216 







... fefftures: birirMri customized interfaces within 
s^TOnTplete documentation, and more, the basic Jupiter J1C package. 

, m M.«im T\VA R H 

Ail Jupiter HC systems feature a sophisticated monitor/debugger package including a versatile 
interrupt system and I/O monitor call instructions. A programmable macro editor and expanded 
assembler are also provided. Proposed ANSI standard BASIC is included with Jupiter IIC. 

THE JUPITER IIC KIT: S2850 

The kit includes the CPU, software debugger and monitor module, 8K dynamic memory, module 
cage, power supply, front panel, video interface, cassette interface, and all llie documentation 
required to assemble, run, and understand the system as well as modification instructions for a 
black and white TV set. 


THE JUPITER IIC ASSEMBLED SYSTEM: $3800 

All components of the Jupiter IIC kit plus two audio cassette units and a 12-inch black and 
white TV set. The complete system is shipped with all components assembled and tested. 


SPECIFICATIONS 

CPU 

MC 6800; eight-level interrupt, 
prioritized and maskable by 
level; single-cycle and block 
DMA 


DUAL AUDIO CASSETTE 
Complete paper tape replace¬ 
ment; start/stop motor con¬ 
trol; 3O0 h 6QQ h or 1 200 baud 
(crystal controlled); error 
correction 


VIDEO TERMINAL 

INTERFACE 

64 x 32 lines 

Upper and lower case, 

plus Greek alphabet; 7x12 format, 

1 28 dot (horj x 96 dot (vert.) 

graphics 


MEMORY 

8K dynamic RAM; 3K ROM; 
IK dual-port static RAM 

KEYBOARD 

Generates full 128-character 
ASCII set 



Q Send details on Jupiter El systems 
FI Have salesman call 

f 

Name _ 


Title _ 

I Company 
f Address - 

* City__ 

I Phone _ 


State 


m 

T TTst 


WAVE MATE 1015 West 190th Street, Gardena, California 90248 
Dept. 203 


Zip 



Telephone (213) 329-8941 


















available to the individual user as well. 


* Appearance and specifications may be changed slightly following acceptance tests 



Uses the 3M Data Cartridge, model DC3Q0. This 
MODEL 3MJ car tndge contains 300 feet of ,250 tape in a sealed 
container. Records and plays at 9600 baud NRZ, 4800 baud P.E. 
Nominal speed 8" per second. Max. recommended flux density 
1200 fepi. Using four tracks, you can store nearly 2 megabytes of 
data on a cartridge. Cartridge measures 4” by 6 :r . Turns counter 
indicates tape position. Inter-record gap light gives more accurate 
position 2$IO(R) is NOT required for use but is highly recom- 
mended for 8080 and Z30 systems. 


COMMON SPECIFICATIONS 


FULL SOFTWARE CONTROL 
of record, play, fast forward and 
rewind. LED indicates inter-record gaps. EOT and ROT are sensed 
and automatically shut down recorder. Can also be manually 
operated using the switches on top which parallel the software 
control signals when not under software control. Signal feedback 
makes it possible to software search for in ter-record gaps at high 
speed, 117V — 60 Hz — 5 watts. 


TWO I/O PORT CONTROLLER WITH ROM ^ 

terminal tiiid ono 

or two cassettes or cartridge units. On board ROM (for 8080 and 
Z30) has terminal and cassette software for turn on and go 
operation. NO MORE BOOTSTRAPPING. Plug in compatible with 
Altair and IMSA1. Loads and dumps memory in Hex from the 
keyboard, formats tape files, punches tape, functions as a word 
processor and searches for files and four letter strings within files. 
Keyboard controls the cartridge units above on rewind and fast 
forward. Special keyboard codes enable you to dump and read 
Phase Encoded tapes as well as NRZ tapes. (Including K.C. Std,) 
Call routines give access to these from your software. 

MODEL 2SIOIR) - With 1 ROM for NRZ Cassettes Si 69.95 
(Assembled & Tested) (Half of above Program) 

With 2 ROMs for Data Cartridges and 
P.E, cassettes, $189.95 (Full Program) 

Kits available for $30 off above prices. 


ivinnpi -5MI “ Uses tlie 3M Data Cartridge type DC 100A. This 
cartridge contains 150 feet of ,150 tape and is the 
same cartridge used by H.P* and others. Runs at 4800 baud NRZ, 
2400 baud P.E, Tape speed adjustable but nominally set at 
5 1 ’/second. Maximum recommended flux density 1200 fcpi. 
Cartridge measures 2'l/8” by 31/4*'. Ibis model is ultra compact, 
yet extremely capable. It is intended for word processing, mailing 
list use and other applications requiring the compact storage of data. 
Data location is by inter record gaps and automatic file search. See 
Common Specs and 2SlO(R) below, 2SlO(R) is NOT required for 
use, but is highly recommended for 8030 and ZS0 users. 

For 8080 and ZSO users: Comes complete with software program 
listings for the programs on the 2S10(R) ROM below. 6300 
software is being written but not yet completed. These programs 
give FULL SOFTWARE CONTROL. 

CARTRIDGE AVAILABILITY Cartridges are made by 3M ( ITC, 
Wabash and others. They are available at all computer supply houses 
and most major computer service centers. We can also supply them 
at normal current list prices. 

-.pyy AUDIO CASSETTE INTERFACE* Phase Encoding inter* 
face for use with audio cassettes or NRZ recorders. Runs 
2400 baud phase encoded on good quality audio cassette recorders. 
May also be used with 2SlO£R) above to use the 2SIO(R) cassette 
programs with your audio cassette player. Can also accommodate 
'TarbeU" tapes and K.C. Std, tapes. $50.00, Wired & Tested, 

$35.00, Kit Form. 

*NOTE: You do not require an interface with the 3M1 and 3M3 
unless you Phase Encode, But, you do need an interface 
to use the 2$lO(R) with your own audio cassette, 

1 ‘COMPUTER AID” and “UNIBOARD” are trademarks of the 
NATIONAL MULTIPLEX CORPORATION. Tim 3M Data 
Cartridges are covered by 3M Patents and Marks, “UNIBOARD" 
Patents Pending. 


OVERSEAS. EXPORT VERSION 220 V - 50 Hz. Write Factory or — Datameg, 8011 Putzbrunn, Munchen, Germany; Nippon 
Automation S-16-7 Shiba, Minato-Ku, Tokyo; EBASA, Enrique Barges, 17 Barcelona, Spain; Hobby Data, SpireaVagen 
5, Mahno, Sweden; G. Ashbee, 172 Ifield Road, London SW 10-9AG. 


For U,P,S. delivery, add $2.00 each item. Overseas and air shipments charges collect. NJ. Residents add 5% Sales Tax. WRITE or CALL 
for further information. Phone Orders on Master Charge and BankAmericard accepted. 

NATIONAL MULTIPLEX CORPORATION 

——— 3474 Rand Avenue, South Plainfield NJ 07080, Box 288. Phone (201) 561-3600 TWX 710-997*9530. 











John Craig 


Kilobaud , The name brought ft*rlh 
smiles, moans of despair, laughter 
(even side-splitting on occasion), grins, 
angei, and cheers, In a few (very fen} 
instance* tt was received with apathy. 
Which was okay* because if there was 
one thing we didn't want, it was an 
apathetic name! But. what the heck, 
A name doth not a magazine make. 
You're not going to be reading these 
pages month after month because of a 
name, right ? No, the incentive for that 
wili most surely be provided by the 
content* 

As the "high capacity data chan¬ 
nel" for the personal computer com¬ 
munity* Kilobaud will be doing it's 
utmost to bring you the latest* most 
practical, interesting* and provocative 
material to he found anywhere. And* 
just so there's no mistake regarding 
our purpose, let me restate it: Kilo* 
baud intends to promote the fun and 
practical application of personal com 
puter systems, 

One of the ways we Ye going to 
attompI ish this is by praviding a 
mcans for the beginner to get started 
and keep going with this hobby. Bui 
let's stop right there for a moment 
and define "beginner." I'm referring 
to the novice* the person who has 
never been exposed to a computer, 
and at the same time to the ex¬ 
perienced computer type, “There is the 
hardware type who is a "beginner" in 
the software area and could use (and 
wants) some good programming tech¬ 
niques, tricks, and tools to help him 
along. I'm also referring to the ex¬ 
perienced software type who is a 
"beginner" when it comes to flip- 
flops* pull-ups, power supplies* In¬ 
state* logic* cross-crsupkd NANDs* 
and all the other glitch generators we 
call hardware. Jn most cases that 
programmer is going to be just as 
interested in how to debounce a 
switch as the hardware type is in 
doing a shell sort. Which bring* up 
two very important points. Number 
one, we Ye going to do everything 
possible la ensure that we're all 
talking the same language. In other 
words, the "buzzwords" will either be 
eliminated or defined in a glossary 
contained in each issue, (A couple of 
prime candidates might be "de* 
bounce" and "shell sort.") Number 
two* we're going to accomplish all this 
by writing for each other. The pro¬ 
grammer will, cjf Course, have to sit 
down and write an article for the 
hardware type on using a shell sort. 
He* in turn* will have to explain a 


* Re] i ltd r*d [ r iirj*i mar k. (M□ E la nal 
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d eh ounce circuit to ihe programmer* 

Now ... to elaborate on that last 
puini, YouVe not going to see articles 
in Kilobaud where that programmer 
a of Tun simply says* "Here is a shell 
sort* 11 Nor are you going to sec one 
where that hardware author says* 
"Here is a debounce circuit." No* I'm 
afraid that approach would be a little 
dry. The hardware type needs to 
explain Ur us vuftware-oriented types 
whal happens during data entry with a 
"noisy" switch (t.c.* why is the de¬ 
bouncing important), several methods 
or circuits to accomplish the objective 
(with a discussion of why one circuit 
is better or worse than another}, the 
nuts-and-bolts Implementation of the 
circuit, and any other practical can* 
side rat ions. Likewise* the programmer 
is going tu have to tell us hard¬ 
ware types why we would want to use 
a shell sort. Wh.it arc the advantages? 
How does it compare to other sorl 
routines? Is one more suitable for 
certain applications than the other? 
And of course the nuis-amJ-bolls again 
- * * in this case in the form of llow- 
charts and the actual program. 

Another way Kilobaud will strive to 
gel people tunicd-on to personal com¬ 
puter* by providing articles dealing 
with applications. We Ye going to have 
articles dialing with the man} possible 
home applications (entertainment, 
education, accounting, environmental 
control, etc,); but, once again* the 
material will he presented in a down- 
to-earth manner which we can .ill 
understand and gel the most out of, 
(Quite some time ago I was told by 
the editor of another magazine in Ihis 
field that if I wanted his respect 1 
would make sure the articles 1 selected 
were as technical as possible. I won't 
bother you with the details of my 
reply; but I dtd want to point out that 
his magazine has an approach w hich is 
different from ours .., and if you're 
looking for the "heavy" stutf* took 
there.) 

Speaking of writing . .. it's inter¬ 
esting that, in view of the I act we've 
made such a big deal out of Kilobaud 
being a nomPh.D. magazine* wc seem 
to have wound up wnh a lot of Ph.D.s 
writing for the magazine. Needless to 
say* they Ye not writing for Ph.D.s . .. 
they all have that ability to get down 
in the brass tacks and explain things 
in every day * easy-to-undent and terms. 
Thai's really the only criteria for you 
to write for Kilobaud too. We Ye nm 
particularly looking for professional 
writers, Kilobaud is going to be a 
loose, informal hobby magazine juxl 
like 73 Magailrtt is for amateur radio 
enthusiast and electronic experimen¬ 


ters. H you Ye toying with any 
thoughts about writing for Kilobaud t J 
feel it's only fair to warn you about 
the mo/fei He pay out tolsa bucks 
fur good material ... so be prepared! 

Where's it all going? 

If you're thinking this personal 
computer "movement" is going to 
remain in it's current state (i.e. f 
limited to several thousand enthu¬ 
siast) you're wrong. We're going to 
see I his tiling bust wide open in the 
near future. For example* a couple of 
mu 11 imiHiun dolljr companies are 
going to introduce home computer 
systems in 1977. One of these com* 
parties will use (from what I've been 
told) nationwide TV ads to sell their 
system. 

Stop and picture the following 
situation for a moment: You are Mr. 
and Mis, Average American who still 
consider a computer as nothing more 
than a mistake-prone monster. It's 
Tuesday evening at 8 pm and you're 
settling back in the oV easy chair to 
watch some TV. A commercial comes 
on. A commercial for a home com¬ 
puter system? What next! But wait, 
this looks interesting. They're showing 
you bow easy this thing is to use (Le,, 
bring it home and turn it on} and 
some of the interesting things it can 
he Used for. There are some really 
neat enter*a in merit programs available: 
chess, checkers, video games (look, 
there's "TANK"!}, Qubtc, as well as 
some practical programs for around 
the bouse, such as an accounting and 
Ux preparation program and index 
programs for magazine articles* 
recipes, etc. Also demonstrated in this 
GO second ad are some educational 
programs which include math exer¬ 
cises. 

Now* since you Ye one of the 
millions of gadget-conscious Ameri¬ 
cans* and assuming the ad convinced 
you "that you just have to have one 
ul these," there's a good chance 
you're gonna go out and buy one! 
There arc three things which will 
Convince the American public they 
should have a home computer: !)The 
case with which it can be used (i.e.* 
not having to learn to become a 
programmer, being able to simply load 
a program in from an ordinary cas¬ 
sette recorder, etc.}; 2} The 
uniqueness and practicality of having 
one (which could be a problem; but 1 
don't think so if some good applica¬ 
tion programs are offered); 3) And 
last, bid not least, the cost. And that's 
the clincher It's so low that I've been 
sworn to secrecy. Wait til you see tt! 

Ihe above scenario will take place. 


And, if It's not with the company I'm 
thinking of* it's just a matter of tone 
before another one comes along and 
does it. The potential side effects are 
mind-blowing! The number of boards 
built for the Alblr bus is staggering; 
but you ain't seen nothin* yet! Just 
wait until companies start jumping on 
the bandwagon with this one. (Wc 
may even have some further complied* 
tionx thrown into The works by a 
"battle" shaping up over which bus 
will become the standard*) 

All of that brings up another 
thought. The biggeex have begun lo 
take notice of what's going on. Digital 
Equipment* for example, recently 
came out with their Direct Sales cata¬ 
log for the single-quantity purchases 
of the hobbyist. Plus, their LSI-1 1 has 
had some success within the hobby 
community *.. and they’d like to see 
n increase. Another interesting point 
regarding DEC and the hobby com¬ 
munity is that 1 recently heard they 
are going to develop an All air bus 
interface so their customers can take 
advantage of low-cost memories and 
oilier goodies available. Then we have 
National Semiconductor. Without a 
doubt, Ihcy're making a thrust into 
Ihe hobby market. And, I think we 
could put Motorola into the put also. 
In the months to come I'm sure we’ll 
sec even more of them waking up. 

Ihe Computer Faire 

Ahli ... there’s nothing like a faire 
in the springtime. And we’re going to 
have a beaut this spring! The first west 
coast computer faire wilt he the first 
major convention held on the west 
coast lor the hobbyist community, 
and even more significantly, it will be 
somewhat of a "homecoming" since 
it’s going to take place in the San 
Francisco area ... which is where 
most of it all began (in the "Silicon 
Valley"). Jim Warren, editor of Dr* 
Dobb’s Journal, and Bob Reding, 
editor of the Homebrew Computer 
Club Newsletter, make up the brawn 
and brains behind this venture; and 
with their collective talent behind it 
wc should have quite a show. 

Following is a list of major topics 
for seminars and informal talks which 
arc being planned: 

* Hardware, Software &. Systems for 
Home Word Processing 

* Speech Synthesis Using Hume Com¬ 
puters 

* Computers & Systems for Very 
Small Businesses 

* M icropr ogrammable Micro¬ 
processors for Hobbyists 

* Digital Cassette Tape Standards 







* Program & Data Input via Optical 
Scanning of Bar Coded Information 

* Personal Computers for Education, 
which will have associated with ir r a 
University of California short-course 

* Computer Graphics on Home Com¬ 
puters 

* Computer-driven & Computer- 
assisted Music Systems 

* Personal Computers for the Physi¬ 
cally Handicapped 

* Computers & Amateur Radio 

* Peripherals interface & Bus Stan- 
dards 

* Software Design, Modularization & 
Portability 

* Floppy Disc Systems for Home 
Computers 

* Computer Games — Alphanumeric 
& Graphic 

* Discussion Sessions for Computer 
Club Officers, Convention Organ¬ 
izers, Club Newsletter Editors, etc. 

Other Conference Sections will be 
added as topics are proposed and 
speakers are found. 

|im and Bob are looking for 
speakers for the areas listed above; so 
if you're interested, be sure and drop 
them a tine for further information. 
(HI be giving a talk on Low-cosi Small 
Business Systems.) Contact: Jim 
Warren, Faire Chairperson, Star Route 
Box 111, Woods id e CA 94062, (415) 
851-7075; SSI-7664; 323-3111 or 
Bob Reiling, Operations Coordinator, 
193 Thompson Square, Mountain 
View CA 94043, (415) 967-6754. 

The First West Coast Computer 
Faire will be held in San Francisco 
Civic Auditorium on April 15, 16 and 
17, 1977. 

Where’s all the software? 

Why are people still silting around 
developing language processors and 
editors Tor the 8080 and 6SG0? I'll lell 
you why. Even though these packages 
have already been developed, a large 
number of people got into this thing 
as a hobby so they could develop just 
that kind of software (for fun). 1 can 
relate to that . . . but darn, I sure wish 
they’d pour their efforts into the 
development of some good applica¬ 
tions software! (I mean, we could sit 
around doing the same old thing for 
the next five yearsl) None of us ever 
slop hearing that question, “Yeah, but 
what do you use it for?” Aside from 
answering that it is simply our toy and 
we enjoy it as a hobby, it would be 
nice to have the little monster doing 
some practical things. Not only to 
impress the neighbors, and ourselves, 
but to help justify the thing to the 
lady of the house. 

And what's all this jazz about the 
Intersil 6100 being able to run PDP/S 
software? I haven’t heard of anyone 
really going to town on this one. If I 
have a 6100 machine with a paper 


tape reader interfaced, can I take a 
PDP/8 program and read it right in 
and run it? What aie the constraints, if 
any? Will ait PDP/8 software run on 
the 61007 What about the restrictions 
regarding DMA, and how can they be 
overcome? What are the mechanics 
involved in getting hold of the vast 
amounts of PDP/8 software which has 
been developed over I be years? And 
what about the cost? Sounds like 
material for what could be one of the 
most significant articles anybody has 
seen in a long time. {Last minute t fa sit 
. . . just got a phone call from Steve 
Diamond of Intersil, and he's going to 
answer those questions in an up¬ 
coming article.) 

If you've written any good pro¬ 
grams that you'd like to share with 
the rest of the world, then how's 
about submitting them to the Kifo- 
butaf Software Library where they 
will he exposed to nationwide distri¬ 
bution? Kilobaud will pay a healthy 
15% royalty to the author/program¬ 
mer also. In the second issue of 
Kilobaud we'll have the criteria for 
submitting programs to the library. It 
should be pointed out that you don't 
have to be a tup Grade A professional 
or semiprofessional programmer to 
submit programs to the Library or for 
an article in the magazine, fust so is 
runs. You're going to be seeing pro¬ 
grams in the pages of Kilobaud writ¬ 
ten by beginners. (Those ol you who 
aren't, at least remember what it was 
like, right?) They're not going to be 
perfect programs* and in many cases 
I'm hoping the professionals among 
our ranks will drop a letter to the 
editor (or whatever) and point out 
where the author went wrong. . . and 
just as important, how it should have 
heen done. In other words, we're 
going to do everything we can to 
encourage people to sit down and 
develop programs and write about 
them. I certainly don't want m rum 
anyone off (newcomer or profes¬ 
sional) by rewriting their programs to 
reflect my style or interpretation. 

Looking back 

Sometimes it's kind of fun lo take a 
look back and see where we've been, 
and in some cases it gives us bet ter 
perspective on where we're going. 
Since the computer hobbyist move¬ 
ment is such a new thing, we're not 
going to be able to go back very far. 
You know, aside from a handful of 
home brewers, this whole llung is only 
2 Yz years old . . . having heen started 
by Jon Titos' article in the June *74 
Issue of Radio Electronics on building 
the Mark-8 minicomputer. The Mark-8 
was an 8008-based microcomputer 
which had some problems (which 
most people managed to overcome); 
but looking at the big picture, and 
what it started, I'd say it was quite a 
machine! Let's go back and see what 
things were like mo years ttgo in 
January of 1975: 

— The recently formed digital 
group in Denver CO was offering (for 
57.50!) complete schema)res and soft¬ 
ware developed by Dr. Robert Surfing 


lor interfacing a cassette recorder to 
the Mark-S, along with a cassette 
containing a bunch of useful pro¬ 
grams: cassette load/dump, TVT & 
Keyboard interface, memory tests, 
and more. 

An 800H microprocessor chip 
was selling from $50 to $60 (not too 
many people were even considering 
the 8080 at the time because of its 
$175+ price tag). 1702 PROMs were 
selling at $40, and 1101 RAMs (that’s 
256 x I bits, folks!) were selling 
any where from $3 to $5. 2102 RAMs 
(w/8008 interface) was Creed TTYs 
selling for 5145. (As a matter of fact, 
the CREED is still alive and well. See 
Art Child's article tin paper tape 
devices in next month's issue,) 

The hobby world was in deep 
wonderment and consternation over 
the recently announced Alt,nr 8800. 
Apparently Ml TS wasn't expecting 
the response their new baby brought 
Forth, and as a result they were caught 
with their guard (and delivery sched¬ 
ules) down. In retrospect it looks as 
though they came out of it all pretty 
well. It's for sure their impact has 
been fell within the hobby com¬ 
munity . . . and will very likely con¬ 
tinue to be felt in the future. 

CACHE (The Chicago Area Com¬ 
puter Hobbyist's Exchange) had its 
beginning about this time. The first 
Chicago club was started by Robert 
Swart/, Bub Cook, Mark Condic, and 
Don Martin of Martin Research. Don's 
8008-based MOD-8 computer was 
probably the 2nd in popularity with 


the hobbyist two years ago. He was 
really after the industrial market, 
though, and published a book entitled 
Microcomputer Design which sold for 
$100 (or $120 with an 8008 chip), (It 
was printed un red paper to dis¬ 
courage copying!) 

I he fifth issue of the Micro-8 
Newsletter was about ready to be 
mailed out by Hal Singer and John 
Craig (that name sounds familiar). 
Incidentally, Ha) still has back issues 
of the Newsletter available at a 
nominal fee. Why don't you drop him 
a line at the Cahrillu Computer 
Center, 4350 Constellation Road, 
Lompoc CA 93436 (otherwise, he's 
going to wind up using those things to 
start his fireplace in the years to 
tome). 

The Kilobaud Glossary 

As a regular feature each month, 
we're going to publish a glossary 
which will define any and all buzz¬ 
words we spot in the articles for that 
issue. There is, of course, the rare 
possibility that we could make a 
mistake and let one get by us. If that 
happens, be sure and drop us a line 
and tell us about it. As a matter of 
fact, if you should happen to run 
across new phrases or words any you 
discover the meaning for, then drop 
me a line about it and we'll share it 
with the rest of the world. 

I should point out to potential 
authors that the glossary doesn’t mean 
a green light to freely use buzzwords 
throughout your articles. Not at all! 
Well, let me clarify that .., you can 
use them all you want ... just explain 
them in the text. The glossary is 
primarily for catching the "loose" 
ones, m 


KILOBAUD SWEEPSTAKES DRAWING 



Pretty ten year old Diane Mat hie son of Trenton , New jersey drew the winning 
card from our 73/KR sweepstake's box at PC 76 while Jim Xfueh/et i looks on 
with anticipation. The tacky winner, Myron Young, jr> of Pasadena, Texas, has 
a Windjammer Crime of the Caribbean for two in his future. 
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NEW PRODUCT 

ANNOUNCEMENTS & REVIEWS 

Kilobaud will be doing its best to keep you abreast of the Idlesl new products 
as they apply to the hobbyist market. You won't be seeing announcements 
here for two, three and four thousand dollar processors and peripherals because 
our feeling is that equipment in that price range was developed for 
in dustri a I/commercial users, rather than the personal small system user. We 
would like lo review each new product that comes un the market to give you a 
good objective evaluation of it; but that simply can’t be done. (This is why 
we're so anxious to see articles or letters written by hobbyist consumers 
describing their experiences with something they f ve built and/or used.) We will 
also make every attempt to establish the integrity and reliability of companies 
sending us new product announcements. — John. 


Continental Specialities Corporation 
Proto-Board 

It would be pretty tough to come 
up with an easier way to design 
circuits than CSCs new Proto-Board. 
Models range from the PB-6 f with 360 
solderless tie-points (in kit form for 
$15.95) to the PB-203A with over 
2250 tie-points and built in '/? amp 
-5-15 and -15 volt adjustable regulated 
power supplies (selling price $120.00). 



Alt models are set up for intercon¬ 
nection, so you can multiply for 
greater capacity. Terminals are 
5-point, with the manufacturer claim¬ 
ing a thousand applications. The 
Proto-Boards are not only the newest 
thing in breadboards, but an experi¬ 
menter’s delight. 

For Further details, contact Con¬ 
tinental Specialties Corporation, 44 
Kendall Street, Box 1942, New Haven 
CT 06509. 

Continental Specials tes Corporation 
Proto-Clips 

Continental has added a 24-pin 
Proto-Clip to its line, after strong 
success with their 14- and 16-pin 
models. There simply isn’t an easier 
w j ay lo bring leads up from crowded 
circuit boards or to wire unused cir¬ 
cuits into existing boards. 

The dips are one piece high-impact 
plastic, eliminating springs or pivots. 


Contacts are noncorroding nickel- 
silver, and there are Proto-Clips avail¬ 
able with prewired cables, in the 14- 
16-, and 24-pin configurations. 

One of the best features of the dips 
is their cost. Only $6.50 for 24-pin 
models, less than $5.00 for 14- and 
16-pin clips. A must for computer 
hobbyists’ troubleshooting kits. 

For additional data, contact Con¬ 
tinental Specialties Corporation, 44 
Kendall Street, Box 1942, New' Haven 
CT 06509. 

Advanced Data Sciences Univue 
Enclosure 

Looking for a place to put your 
keyboard, keypad, video display 
generator, or microprocessor? Ad¬ 
vanced Data Sciences has just what 
the doctor ordered. It's a two piece, 
aluminum and steel, low profile 
enclosure, with over 200 cubic inches 
of space. Included in the package is a 
flush mounting aluminum front panel, 
which can be easily scribed and 
drilled for mounting purposes. Since 
it comes off the enclosure with six 
self-taping screws, the panel can be 
spray painted to match your equip¬ 
ment, making for a dean, professional 
package. Surface area of the panel is 
23" X S". 

Aside from microprocessor applica¬ 
tions, the Univue is also applicable to 
keyboard Morse, RTTY, and a host of 
other uses. Including rubber feet and 
mounting hardware, the Univue sells 
for $32.95 plus postage and handling 
from Advanced Data Sciences, PO 
Drawer 1147, Marion OH 43302. 

International Data Systems, Inc. 

Introduces Altair 8800/1MSAI SQK0 
Compatible Time of Day Clock 

The time of day is now available for 
Altair 8800, I MSA I SOSO, and bus 
compatible systems from the new IDS 
model 5 PM-88 dock board. Current 
time Is read from three consecutive 
I/O addresses which are selectable in 
increments of four addresses. No wails 
are required during clock set or read. 


This low power board requires less 
than 400 mA from the +8 V supply 
and is well below the Altair bus power 
specification. 

The SPM-88 keeps lime using the 
60 H/ ac line as a reference source 
(which is very accurate), but pro¬ 
visions arc also included for optional 
50 W line sources, onboard crystal 
controlled time base, and external 
battery backup power. The printed 
circuit board is made of high quality 
glass epoxy with gold plated edge 
contacts. 

The 5PM-8S does not toad the CPU 
in any way except when I/O is exe¬ 
cuted lo set or read the dock. The 
time is maintained completely on the 
SPM-88 in contrast to the previously 
available alternative which requires 
interruption of the processor and 
actually keeping time in software. 
After the SPM-88 is Initially set it 
keeps time even when the CPU is not 
in run mode, while loading programs, 
etc. 

Software is included with the 
SPM-88 kit to set and read the clock 
from MITS BASIC, Processor Tech¬ 
nology BASICS, and from assembler 
for nonBASIG applications. Software 
is also included to maintain either 
calendar of Julian date if desired. 

The SPM-S8 is available in kit form 
for 196.00 postpaid and is complete 
with all necessary components and 
instructions. Options include 1C 
sockets for all ICs ($10,00), crystal 
time base ($25.00), 50 Hz operation 
instead of 60 Hz (no charge, specify 
SPM-S8/50), Delivery is stock to 30 
days and orders may be sent directly 
to International Data Systems, Inc. at 
Post Office Box 593001, Miami FL 
33159, 

RO-CHE Multi-Cassette 
Controller 

RO-CHE Systems has just intro¬ 
duced a new Multi-Cassette Controller 
for the 8080 CPU microprocessors. 
Their "Magic Black Box" controls up 
to four cassette recorders with a 
Tarhell or MITS cassette interface 
board. This unit handles records, 
that's right — records, to be read or 
written like a BEG system with four 
tape drives. 



The status bits generated by ihe 
interface boards are software con¬ 
trolled to select which recorder to use 
and, whether to read or write, and lo 
start and slop the cassette. LEDs on 
the face of the controller indicate 
which deck has been selected and 
when that deck is writing. 

The software that comes with the 
unit provides operator instructions to 
position the tape, put it in read mode* 
etc. Additional messages also provide 
for read error recovery. When an input 


file is opened, the recorder reads to 
the first file mark of the file and 
stops. An error message indicates 
when a tape is positioned past the llrst 
record. 

To write a record merely load the 
deck number into the accumulator 
and call the write subroutine. When 
the logical output buffer is full, a 
compressed (no blanks) physical 
record is written on the cassette tape. 
The read routine places a physical 
record from the cassette into the 
input buffer and replaces the blanks as 
logical records are used. 

The records are written in a formal 
similar to that proposed by Charles H. 
Eby on page 43 of the June, 1976, 
issue of Interface, titled "Cassette 
Tape Format Standards," except an 
interrecord gap is used instead of a 
byte count. Logical records may be 
any length. 

Using the four port Multi-Cassette 
Controller ($125,00 in a kit) and 
$39,95 cassette recorders the micro¬ 
processor owner can now have large 
system capability at a smalt system 
cost. For complete information, con¬ 
tact RO-CHE Systems, 7 101 
Mammoth Ave., Van Nuys CA 91405. 

Improved Terminal Positive 
Regulators From National 
Semiconductor 

A new LM140LA scries of terminal 
positive regulators, with several fixed 
output voltages, in three temperature 
ranges. Is now available from National 
Semiconductor Corporation. These 
devices have a 2% output voltage 
specification, 0.04% per volt line regu¬ 
lation, and a .01% per milliamp load 
regulation. This usually results in an 
Improvement of two orders of magni¬ 
tude in effective output impedance, as 
well as lower quiescent current, when 
the LM140LA is used as a replace¬ 
ment for a zener diode/resistor 
combination. In addition, these regu¬ 
lators can be used to provide local 
on-card regulation, thus eliminating 
any distribution problems normally 
associated with single point regula¬ 
tion. 

cortiiinied on N 
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Meet the Challenger. 

B The Challenger 

Seif Portrait 

The new price and performance champ from OSI. 


He's got his act together! 

Even our lowest-cost Challenger 
comes fully assembled, complete 
with a 500 ns 6502A, serial interface, 
1,024 words of memory and a 
UL-approved power supply, all for 
$439. Every Challenger comes ready 
for easy expansion with an 8-slot 
mother board, backplane expansion 
capability, and a power supply 
heavy enough to handle a full 
complement of system boards. Our 
4K Challenger comes ready to run 
BASIC minutes after you unpack it. 
And there’s more. 

He packs some heavy hardware. 

You’ve never seen memory and 
interface options like these—not at 
our prices, fully assembled! 4K 
RAM memory boards $139! {see 
below). Single drive OS! Challenger 
Floppy Disk $9901 Dual drive 
Floppy $14901 Plus 8K PROM 
boards! A Video Graphics board, 
including alphabetics, graphics, 
and color! An audio cassette, 

A/D, D/A and parallel I/O board! 

A backplane extender board! 

A prototyping board! And our extra¬ 
ordinary CPU Expander Board—it lets 
you run a Z-80, and 6100(PDP-8 
equivalent) concurrently with The 
Ghallenger's6502, or under itscontrol. 

There’s nothing soft about 
his software! 

OSI has full software support for our 
Challengers. Including extended 
BASIC, extended Video Monitor, a 
Disk Operating System, some 
very Hollywood real time programs 
for Video Graphics, Animation, 

Sound Processing and so forth, plus 
PROM firmware, with more to come. 

He's fast! 

You can order The Challenger with 
a 65Q2C for a 250 ns cycle time, 
with a standard 6502A for 500 ns 
cycle time, or with a 6800 for 1 
microsecond cycle time. And with 


our CPU Expander Board, you 
can always update to any new CPU 
to be as fast as fast can be. 

And he isn't just good! 

He’s better! By design. The OSI 
Challenger is the only completely- 
assembled, ultra-high-performance, 
fully-expandable mainframe computer 
that does this much for this little. 

Get your hands on one now. 

Send for your Challenger today. 

You can't beat The Challenger! 
The OS! Challenger 65-1K, FuSly 
assembled. Features 6502A CPU, 
serial interface, 1,024 words of 
memory. $439. 

The OSI Challenger 65-4K. Same as 
65-1K but with 4,096 words of 
memory. Will run Tiny BASIC with¬ 
out expansion. $529. 

The OSI Challenger 65V-4K. NO 
NEED for an expensive terminal. 
Connects to your ASCII keyboard 
and video monitor through included 
OSI 440 Video Board. Features 
software utility that simulates a 
deluxe CRT terminal, $675, 

The OSI Challenger 68-1K, Based 
on 6800 CPU. For the casual 
hobbyist, smaller systems. The 
Challenger 68 series comes only in 
serial interface forms and is 
compatible with MIKBug software 
through an included OSI software 
utilities package. $459. 

The OSI Challenger 68-4K. With 
OSI 4K BASIC on paper tape, $529 
SPECIAL! ADDITIONAL 4K MEMORY 
BOARDS. Ordered with your Chal¬ 
lenger, limit 3 more at this special 
Low Price, (total 16K, including 4K 
already on-board in mainframe). $139 
Buy 12K or larger Challenger 65 
system and we include Extended 
BASIC FREE! 



031 Challenger Floppy Disk System. 
Fully assembled, for use with OSI 
Computers only. $990 Single drive 
$1490 Dual drive. 

OSI Audio Cassette Interface. 
Comes assembled, but with room 
for you to populate with A/D and 
D/A chips later. (OSI 430 based) $89 
And all the baseboards and kits of 
the powerful OSI 400 System. 

OK, OSI, I'm ready to buy! 

To order your Challenger System, 
send the total amount of your 
purchase plus S4.00 for shipping and 
insurance (plus sales tax for Ohio 
orders) by personal money order or 
check. Or indicate all numbers 
on your BankAmericard or Master 
Charge to charge your order. 

Or send a 20% (non-refundable) 
deposit to receive your order C.O.D. 
Delivery is typically 60 days (except 
when payment is by check, which 
must clear before shipment can be 
made). Deliveries are scheduled on 
a first ordered, first shipped basis. 

Name,_ 


Address. 

City 


.State. 


„Zip„ 


Telephone^ 


Bank card info Inter Bank 


Expiration Date. 
Account# __ 


Check Q M. O, □ BAC □ MC □ 
20%, bal. C.O.D. □ 

□ Order attached. 

□ Send additional informa¬ 
tion on The OSI Challenger. 

□ Send additional informa¬ 
tion on OSI 400 Kits. 

□ $1.00 enclosed 
for complete 
OSI Catalog, 


OHIO SCIENTIFIC INSTRUMENTS 

Dept. KB 11679 HAYDEN STREET, HIRAM, OH 44234 



(216) 569-7945 













Can Somebody Out There Help Me? 


As a “software” person who hadn’t 
heard of TTL 18 months ago and has 
little idea of how a regulator or op 
amp works, I would like to mention 
some articles on hardware. You said 
Wayne Green . was confused by 
advanced articles about software in 
other computer magazines. I am 
confused by simple articles in 73 
about transistors. Don’t forget, for 
every ham operator who knows elec¬ 
tronics and wants to program there is 
a programmer who has always wanted 
his own computer but does not know 
how to build those “little things” that 
always get left out or added on at an 
exorbitant price (like keyboards and 
power supplies). You guys know 
about how those things work - tell us 
about it and double your audience. 

Some examples. Almost every 
computer kit comes missing the key¬ 
board ($50-200) or power supply 
($100-200). So how do you build one 
or buy one surplus? Hams probably 
do that as their first project, but 
programmers don’t - they do sorts. 
I’m building a power supply for my 
SC/MP. It’s the first thing I have ever 
designed and built (always Heathkits 
before). I’ve learned a tremendous 
amount about the basics which never 
get mentioned (e.g., how to drill holes 
in aluminum, where to buy surplus 
transformers, etc.). I’ve also learned 
about using regulator chips; the article 
by James Kucera in September 73 was 
very helpful. But I've Just begun to 
learn how tittle I know. 

Here are some simple questions a 
non-PhD non-ham might have. t. How 
does a transformer work? Are there 
differences I should worry about? 
How does a high current transformer 
differ from a low current transformer? 
Does 12.6 V ac mean peak-to-peak or 
RMS? 2. How does a diode work? 
How do they differ? When do you use 
bridge, full wave, or half wave rectifi¬ 
cation? What is piv and why do I seem 
to need 200 to 600 piv for a 12 volt 
supply? 3. How does a capacitor 
work? I know that electrolytics are 
big but what is the difference between 
small electrolytics, tantalums (more 
expensive), and discs? When do I use 
which? How do I choose one, and 
what should I watch out for if I buy 
surplus? What are mfd, ufd and WV 
dc? 4. What are the trade-offs in using 
a center tapped transformer with full 
wave vs not using the center tap and 
using a bridge? This changes the 
voltage/capacitance needed. What is 
the cheapest/best way? If I use a 
surplus capacitor rated for 70 WV dc 
at 20 V, do I get more farads? 5. The 
voltage regulators — does it matter 


which one I use? 

More advanced topics. 1. How do 
you keep noise from motors and 
things out of the power supply? What 
commercial power line filters are avail¬ 
able? How do I make my own? 2. (A 
big one!!!) How do pass transistors 
work? Some designs use PNP, others 
NPN. What’s the difference? How do I 
find cheap ones? How do I design 
with them? What is B, lb, Vceo, etc? 
A series pass transistor is a lot cheaper 
than 5-10 regulators. 3. OK, I used a 
pass transistor, now how do I protect 
my chips? What is an SCR? How do I 
use them? What is “fold back over 
voltage protection”? What kinds of 
overcurrent and overvoltage protec¬ 
tion is available? 

Now that I’ve designed it, how do I 
build it? How do you mount a T03 
transistor? Do you need insulation or 
heat sink grease. My -12 volt regulator 
uses the case as input, not ground, 
what do I do? 2. How do I wire the 
rectifier? What kind of heat dissipa¬ 
tion is required? 3. When do I use a 
breadboard (I didn’t but probably 
should have)? How do you connect 
things to it? 3. What about switches 
and fuses? Amateurs may know about 
such things when they are born but 
programmers don’t. You switch the ac 
line, I suppose, but what do you fuse? 
Will a fuse save the chips? Do regula¬ 
tors ever fail? 

Even more advanced topics. 1. 
Switching supplies, how do they 
work, how do I build one? Why do I 
want one? An article on how to build 
a 10-25 Amp 5 volt switching supply 
that takes up no space and puts out 
no heat would be great. 2. Rewinding 
transformers, is it hard? Surplus trans¬ 
formers with reasonable voltages and 
currents can be found, but sometimes 
an extra volt or two would really help. 

What if I don’t want to design and 
build myself? Where can I get a good 
cheap power supply? What OEM sup¬ 
plies are available? What about the 
Heathkit 7.5 volt 10 Amp supply for 
$80? 

A power supply is basic and so is a 
keyboard. Altair, I MS At and SWTPC 
have power supplies of various quali¬ 
ties but you pay dearly for a key¬ 
board. Where can I get one? There is 
an unencoded 63-kcy keyboard avail¬ 
able for $20.00, how do I encode it? 
What should I look out for — no lower 
case ASCII, not ASCII, etc.? What can 
I do to change from Hollerith or 
Baudot to incomplete or complete 
ASCII? Where have all those cheap 
Baudot teletypes gone? I have not 
seen one in many visits to surplus 
stores. When do I need complete 
ASCII? When do I need lower case? 
What about roll-over? What is it? Who 
cares? (If you need it and you don’t 


have it, roll-over is very frustrating.) 
What are solid state keyboards? How 
do they work? Are they worth the 
money? How do you make a case for 
a keyboard or a printed circuit board 
for an uncncoded keyboard? What 
kinds of MOS encoders are available? 
Which ones have all 128 ASCII char¬ 
acters, which are upper case, which 
arc TTY type? How do you make a 
TTL encoder? Some sense switch 
closures while others scan the key¬ 
board. How do I do it? 

Hams and programmers alike know 
the difference between hardware and 
software. Hardware costs money and 
can be broken or burned up. Software 
takes time (which for a "hobbyist” is 
not money) and is generally non¬ 
destructive. A program that doesn’t 
work just needs a little study. You put 
out hard cash for a burned up 8080. 
(How about an article on static and 
MOS devices? How much grounding is 
required and how do you do it. It’s 
easy to say ground yourself and your 
workbench but docs that mean I have 
to wear aluminum foil and hold onto 
a water pipe or what?) All hobbyists 
have one thing in common, tots of 
time and little money. 

Amateurs have known tricks for 
years: how to make surplus equip¬ 
ment work; how to buy surplus trans¬ 
formers, capacitors, switches, etc., and 
save 80%. Programmers like me must 
learn these things. We aren’t rich 
either and can’t afford to spend $200 
for a power supply when we could 
make a better one for $50. But we 
can't afford to burn up $250 worth of 
chips either. 

So help us, and we can help you. 
My questions may seem trivial to you, 
but I know what an assembler, 
compiler, and interpreter are. More 
than Vi the members of the San 
Gabriel Valley Chapter of SCCS are 
programmers who want to build their 
own system. Help us in Kilobaud with 
simple hardware articles, and we’ll 
build our systems and write cheap 
systems software to revolutionize 
home computing. Working from both 
directions, we can get there in half the 
time. 

Bill Pearson 
Pasadena CA91125 

Wow! Beautiful / What can I say 
except " Yes, / agree.** Potential hard¬ 
ware authors ... go back and read 
Bill's letter again. - John. 



I really enjoyed your articles about 
computers in the Aug. 76 issue of 73. 
I am 14 years old, and before we 
moved to Texas, I used to be real 
good at computer programming. The 
middle school that I used to go to had 
several terminals connected via tele¬ 
phone to the main computer at West- 
field High School. The computer was 
a Digital PDP/11, BASIC language. 
The school I went to taught computer 
programming starting in grade 6. (The 
name of the school is South Middle 
School.) When we moved here, I 


found out that computer program¬ 
ming is not taught until 11th grade! If 
there is any way that I can use a 
computer near here, will you please 
let me know? I really enjoyed com¬ 
puter programming in BASIC language 
and would love to do it again. 

Tom Trusty 
2613 Lynnwood Dr. 
Arlington TX 76013 
1-817.274-7998 

Anyone know of a local computer 
group? Contact Tom. - John. 


Mid-America Computer Hobbyists 


Congratulations on the introduc¬ 
tion of Kilobaud. I hope that you 
hold to your promise to provide intro¬ 
ductory and intermediate level 
construction and software develop¬ 
ment articles for us neophytes to the 
world of Hobby Computing. If you 
can find room in Kilobaud , pteasc 
announce the organization of MACH, 
Mid-America Computer Hobbyists. 
Our primary purpose is to exchange 
ideas and information on construction 
and software development projects. 
Interested individuals can contact me 
at the following address and I will 
send them information on our next 
meeting. 

Russell W. Steele 
MACH 
838 Gayle St. 

Papilllon NE 68046 
Attention: Club Secretary 


More Reader Requests 


I would like to offer a few sugges¬ 
tions as to what I would like to see in 
the new magazine. First: peripherals 
should be stressed (this is beyond the 
usual TVT or video display). A set of 
peripherals can make a computer into 
a useful system. For instance, my 
system has two digital cassettes, a half 
inch mag tape unit, a paper tape 
reader and punch, a slowly developing 
graphics display, as well as the Flexo 
writer this letter is being written on. 
We also need to be able to control line 
powered devices (even if only to 
impress our friends by turning the 
house lights on). 

Standardization needs to be stress¬ 
ed — both software and hardware. As 
an example, the 8080 I/O port con 
vention seems to be standard except 
for the status bits (TBE and DAV). 
Why so many variations? The Kansas 
City cassette standard is an excellent 
idea — the method is terribly slow but 
it is cheap and uses readily available 
parts so that everyone can have an 
interface which will allow him into 
the software pool. 

It is important to generate a soft¬ 
ware library of low cost (about $5) 
programs both BASIC and machine 
language on cassettes and paper tape. 
This goal can only be met if we have 
both standardization and peripherals 
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_ EQ tl^ie Editor' , 

to do interesting things with. How 
ever, any programs offered for sale 
should have commented source list 
i ngs r as a large portion of the fun of 
this hobby lies in modifying things to 
suit one’s fancy. 

In any case, you must be careful 
not to ignore either the software or 
hardware types. We can all gain by 
mutual interaction. What all this 
means is that I hope you and Wayne 
keep the level and diversity of male* 
ial in Kilobaud the wme as in 73. 

Doug Hogg 
36 Callc Capistrano 
Santa Barbara CA 

Needless to soy, Doug , we're hoping 
there are a tot of other people out 
there with the some ideas you've 
expressed in your tetter . . . because 
Kilobaud is definitely going in those 
directions. And , us far as con trotting 
tine powered devices is concerned . . . 
keep your eyes open for an article in 
this issue by Chris Bowick on optoiso* 
tutors. (We /ust think we’re having fun 
nowf Just watt tit we start turning 
everything on and off with these 
monsters! I’m not convinced of the 
practicality r if it alt . ., but tt does 
sound tike fun.) And if you tike 73 
... you're gonna tove Kilobaud! 
John. 


Kilobaud a bright idea 


Dear subscription person (be ye he or 
be ye she)! 

Enclosed is a check for an initial 
sub for Wayne's latest bright idea aka 
Kilobaud in the amount of 512. 

F.YJ. I am beginning to consider 
Wayne’s ‘*BIY + (bright ideas) as 
investment material since I sold the 
first year of my Byte sub for 525 and 
a duplicate first issue for 51 5* A total 
of $40 on a $10 initial investment 
ain't bad. (Plus Byte is still coming, so 
far 15 issues on a 12 issue subscrip¬ 
tion. 

Peace be with you and make sure 
the new mag has a mailing wrapper! 

T. Pappan 
Corunna Ml 48817 


Same Du's and Don't *s 


I'm enclosing $ 12 for a subscription 
to Kilobaud, Sounds like it will be a 
good magazine lor the tinkercr. There 
are so many newsletters and maga¬ 
zines around now that ( have had to 
be semiselect ive about which ones I 
subscribe to. I be main reason l have 
good feelings about Kilobaud is know¬ 
ing that you are involved and 1 liked 
what you and Hal did with the 
MICROS Newsletter. 

I'm looking forward to this new 
venture of yours. 

Let me tell you what I've been 


doing since I last really talked to you. 
When we Iasi left Tommy Tinkerer he 
was fooling with his modified 
MARK-8. Well, l got turned on to the 
8080 before 1 really even used all the 
capabilities of my 8008. In other 
words, I could still be happily tinker¬ 
ing with my Mark-8 except that I 
guess I am just a hardware freak. 
When I saw the 8080, I said, "Now 
there's a processor 1 could live with 
for a while/' And I especially liked 
the Altair bus structure, 5o t I paid 
$15 for an Altai r manual* and pro¬ 
ceeded to translate their boards into 
wire-wrap versions. My experience 
with the Mark 8 taught me several 
thmgs, like the value of a "universal 
bus" structure that allows any board 
to go in any slot, and also the prob¬ 
lems that can be encountered by 
having the electrons from the power 
supply regulator travel a long road 
through several connectors before 
gelling to the board where they are 
eaten. I was Impressed with the 
Allah's distributed regulation. Any¬ 
how, imitation being the smcctcsl 
form of flattery. I decided to flatter 
MITS by making myself a personal 
copy of an Altair, executed in wire- 
wrap, 

I had all the parts 1 needed us do 
the job, with the exception of the 
8080 Chip itself, which at this time 
was selling at a price of $150 - a bit 
expensive. However, a microsystem 
manufacturer (who shall remain name¬ 
less) happened to have a certain brand 
of minicomputer in house, with which 
I was somewhat familiar. To make a 
long story short, favors were 
exchanged, their mini ran a little 
better, and: I was the proud owner of a 
brand new (free) 81)80A, 

I had my wire-wrapped Altair 
finished in about a month. Now , the 
moment I was dreading, power on , , , 
rtu smoke . . several LEDs lit, but 
activation of Ihe reset switch quickly 
told me that my creation was not 
alive, not responding. I started from 
the lop, clocks were OK, all voltages 
in spec, front panel one-shots all 
working right, nut lung obviously bad. 
So, I figured the place to start was 
with the EXAMINE switch, which* as 
you know , lakes out a JUMP instruc¬ 
tion from the front panel, pulling a 
”303" cm the bus followed by the 
settings of the HI and LO address 
switches. Scoping the bus showed that 
this sequence was being put on the 
bus OK, "303 LLL IIMH" bui the 
signals looked like they just were not 
gelling pulled up by the data bus 
pul I up resistors. I checked the sche¬ 
mata again. Yes, it said 47k Ohms, 
and that wav exactly what 1 had. I 
tried substituting some 2GK Ohm 
jobs, and as I had suspected, the 
waveform was improved but still not 
good enough. 1 didn't want to go any 
lower on the pullups lor fear of 
causing the 8080 to sink too much 
current and really die. I spent three 
weeks on this problem with no solu¬ 
tion, l was almost ready to give up 
when I suddenly got a terrible feeling 
in my gut, following my List hope, t 


turned lo the parts list in the manual* 
and there was the value of the pull- 
ups: 4.7k Ohms!!! The decimal point 
didn't show up in my copy of the 
schematics and it looked like 47k, 

One hour and eight 4.7k resistors 
later, my machine was up and playing 
music. While fm talking to you. I'd 
like to put in a plug for the Digital 
Group's stuff. I've been using their 
TVT ever since the Mark-8 days with 
no problems. In case anyone is turned 
off by the fact that it has no cursor or 
that you can't do a "screen read,” 
these are not restrictions as a cursor 
can be implemented in software by 
allocating a 256 word screen buffer 
and using a register to hold the cur¬ 
rent position. An underscore char¬ 
acter can be written at the current 
position in the screen buffer and each 
time you input a character, you 
update the buffer and dump the 
screen again. Unlike TVTs with a 
serial interface, a screen dump is 
almost instantaneous, so this is not as 
had as it may sound. I'd also like to 
say some good things about Dr, 
Suding's cassette tape Interface: it 
works. Besides the fact that it works, J 
like the fact that the two frequencies 
it uses arc not harmonics of each 
other. The system is fast and good and 
I am using it with a 10 year old 
Cassette recorder that literally traveled 
in my xcabag in my service days and 
has seen continuous action ever since. 
By the way, I believe the Digital 
Group's new TVT offers twice the 
capacity lor just a small increase in 
price. In short, I'd like lo recommend 
the Digital Group to anyone who is 
considering buying from them (they 
also deliver in this lifetime). 

For people who are buying 
components, I have had very good 
luck with James and also Godbout 
(and Oigi-Key was good). 

Roly Paks is generally high priced 
un most items of interest to micro 
users, but they have some goodies that 
aren’t carried by others* and they have 
had a pretty good delivery record with 
me. 

My one outstanding BAD experi¬ 
ence was with (who else??) Mini Micro 
Marl. Despite all the hap things I had 
heard about them* 1 ordered a calcu¬ 
lator interface from them, along with 
their ”8080 Driver software.” 

What I finally received was the kit, 
missing 8 parts \no 8080 drivers!) and 
a note saying that l owed them a 
dollar for the shipping cost. I sent 
them back a letter saying that I would 
be happy to send them their buck as 
soon as they sent me the missing parts 
and the 8080 drivers. That was 
months and months ago, I have 
received no parts, no drivers, and no 
acknowledgement of my letter. Since 
the missing parts w'ere ones which 1 
had in my own stock, I decided to 
chalk n up to experience and pass 
my wonderful experience on to others 
who may be considering buying any¬ 
thing from these people. By the way, 
the quality of the printed circuit 
board they sent me was the worst I 
have ever seen from a hobby com¬ 
puter supplier. It is a two-sided board 


without plated-through holes; and it 
was not cheap. By contrast, the 
boards put out by the Digital Group 
have plated-through holes and are of 
superior quality, 

Tom Boyko 
Portland OR 97215 



Tam Boyko's Murk SO 


Micro 8 


Sorry to hear that |uhn Craig had 
left the Micro-8 Newsletter. After alt* 
if it wasn't for Micro-8 (originally, 
Mark-8) we wouldn't have had the 
rapid growth in this crazy computet 
fever! That little newsletter helped me 
find my way thru all the confusion 
when l first started 1 Vi years ago! 

Tate Yoshhla 
Chicago IL GOG 16 

t've always feti that newsletter did 
more titan anything else to get the bait 
rotting and t sure enfoyed being a part 
of ir . Keep in mind that it was Hal 
Singer's idea and most of his effort 
that made it such a success. - John, 


Big Plans 


I am already a subscriber to: 73* 
Microtrek, and Personal Computing, 
now you want me to spend SI2 on 
Kilobaud! For anybody else prob¬ 
ably not - but for Wayne Green I'll 
do it anytime. The Kilobaud Uni/ in 
November 73 shows that you have 
made no little plans for your new 
magazine. Your emphasis on beginners 
is important — as even those who 
claim to be "experienced" arc likely 
lo be experienced in only one or two 
areas and rank beginners in others, 
Y our computer lab should be the envy 
of many a retail store! I hope you will 
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to tha Editor 


be smart enough to find some uses for 
all that computational power in the 
business of publishing your two great 
magazines and many books. By the 
way — will you be providing tours of 
your lab for those fortunate few that 
are able to find their way to (he great 
metropolis of Peterborough? 

Your RTTY types ought to be the 
ones most into microcomputers — 
followed by CW (the human voice has 
got to be the worsf tool for data entry 
into a stupid machine - followed only 
by handwriting). As a RTTY type - 
you might think of some ways that 
hams and microprocessor enthusiasts 
might join together for some valuable 
public service activities — both of an 
emergency and nonemergency nature. 
Give your readers some ideas and 
perhaps some of the application pro¬ 
grammers among us can come up with 
some software to match. Keep up the 
good work and — never say die. 

Kenyon F. Karl 
Waterville ME 04901 

Okay Kenyon - programmers please 
note - and visitors? You bet / Love 
'em ... Wayne. 


Sharing — The Lifeblood 
of a Hobby 


During the past several months I 
have become heavily involved in the 
hobbyists computer movement and 
have had occasion to read numerous 
articles, both for and against the sale 
of software to hobbyists by various 
companies. There also appears to be 
great concern over the "piracy” of 
this software by those hobbyists who 
either cannot afford or cannot justify 
the purchase of something as intangi¬ 
ble as a computer program. I would 
like to take this time to voice my own 
personal views on this subject and also 
to introduce to you a new concept 
regarding the distribution of some 
software which I have developed. 

My experiences in various hobbies 
range back over twenty years to my 
involvement in ham radio experiment¬ 
ing. Although I have been out of 
touch with this market for many 
years, I seem to recall a genuine 
interest within the group of ham radio 
enthusiasts in sharing all their knowl¬ 
edge and experiences with others 
involved enough to take the time to 
listen. I feel quite certain that it was 
this high energy level and genuine 
interest to share with others that 
played a great part in promoting the 
hobby to the level it is today and also 
in the various technical developments 
that came about because of the accep¬ 
tance of the hobby. At no time can I 
recall similar instances of concern 
over the piracy of ideas or schematic 


diagrams which seems to loom like a 
huge black cloud over the computer 
hobby market of today. Ham radio 
operators were all too enthusiastic 
about sharing their developments to 
become entangled in the web of legal- 
ities that enshrouds the patent 
infringement laws. It seems to me that 
the few unscrupulous individuals that 
may have profited from someone 
clse’s ideas in the ham radio field 
cannot possibly overshadow the 
opposing mass of those who gained 
knowledge and pleasure from the 
sharing that seemed to prevail. 

My point in this matter is simple; I 
feel that if this is to be a hobby that is 
to be accepted by the general public, 
it should be promoted in a similar 
manner to the tried-and-true tradition 
of ham radio. The sharing of ideas 
with others should be encouraged and 
the profit-making in large volume 
should be left to the commercial data 
processing market which still appears 
to be totally viable, judging from the 
massive amounts of commercially 
available programming talents. I, 
myself, have been a computer con¬ 
sultant to various large firms for over 
six years and have never felt the need 
to charge for programs that I have 
developed solely for the amusement 
or education of those people not in 
the commercial market. I am a firm 
believer in this theory that any energy 
you expend to help others will eventu¬ 
ally come back to you in some form 
or another. The times I have taken to 
assist students in their programming 
endeavors has always seemed to pro¬ 
vide me with new viewpoints on my 
own ideas and has never threatened in 
any way my ability to make a living as 
a professional programmer. The vast 
amounts of talent, that is yet 
untouched, in the new breed of 
computer enthusiasts should not be 
stifled because of lack of assistance 
from those of us who have been in the 
professional end of the field. During 
the past several months I have had the 
opportunity to "hang around” and 
perhaps at times make a pest of 
myself at my local computer hobby 
store, The Computer Mart, in Orange, 
California. I have viewed, first hand, 
the enthusiasm that prevails over the 
range of people buying these fancy 
machines and have been amazed at the 
innovativeness of some of them to 
solve problems which in all practical 
respects should have no logical solu¬ 
tion. These people in the end are 
going to provide us with some genuine 
technology that can do nothing but be 
beneficial to everyone and I feel that 
they deserve all the assistance they 
can get from the professional com¬ 
munity. 

Fortunately, the people who run 
The Computer Mart share in the above 
views and opinions and have assisted 
me in developing a system which I feel 
will be beneficial to those who get 
involved with it. I have developed a 
16-bit microprocessor system which 
will plug directly into existing IMSAI 
and ALTAI R computer systems and 
use all the existing 8-bit memory and 
peripheral gear with little or no modi¬ 


fication. The software that will be 
offered is a modified version of a 
complete commercial operating 
system that I have developed over a 
period of four years and have sold to 
the various commercial users for 
prices that range into five figures. It 
includes a flexible disk-based execu¬ 
tive with timesharing capabilities and 
modular construction which will allow 
the hobbyist to custom tailor it to his 
order. The I/O is file-structured and 
multi-user based with easy to under¬ 
stand subroutines to allow new and 
wonderful I/O devices to be added to 
the system. The system also includes a 
macro-level linking assembler and 
linking loader, an 8080 cross- 
assembler and loader, character string 
text editor, monitor generation 
package, and all utilities necessary to 
maintain the file-structure data base. I 
am currently in the process of devel¬ 
oping a powerful BASIC language 
which will be both interpretive and 
compiler oriented and should include 
most of the popular features currently 
found in the extended BASIC pack¬ 
ages. This is the first piece of software 
of major proportions that I have 
developed which was not under con¬ 
tract to some commercial user and I 
find it quite relaxing not to have to 
work under a set of predefined con¬ 
straints. 

I intend to distribute this entire 
package through the Computer Mart 
for a price that will cover the copying 
media costs and labor involved to do 
the distribution. The tentative price 
we have set for the software system is 
around $50.00 for the entire package, 
including BASIC which will run under 
the executive or as a free-standing 
program. I also intend to make all 
source files available to anyone who 
wants them for understanding or 
custom modifications. The source files 
wilt be available typically on several 
floppy disks, in a formal that is easily 
assembled by the system assembler, 
and on microfiche listings. The docu¬ 
mentation in the form of comments 
within the source files is second to 
none and makes for easy under¬ 
standing by other programmers and 
also by myself. (How many times have 
you gone back to an old program and 
asked yourself "Now why did I ever 
use that register for that routine?" 
and puzzled over the answer for 
several hours?) Additional external 
documentation will be available to 
assist the hobbyists in customizing the 
system to his own personal needs. 

Another service I intend to provide 
is a personal response to all questions 
and comments concerning the system 
or bugs detected (and I'm sure there 
will be quite a few) in as quick a 
manner as I can arrange. A self- 
addressed stamped envelope will be 
the total cost of this service, which 
should be within the grasp of even the 
most insolvent enthusiast. 

I honestly feel that this type of 
attitude is what is desperately needed 
in the computer hobby field to keep 
us all in the current stale of high 
interest and development. Perhaps no 
one will get rich quick by selling 


software for low prices, but I feel 
there are enough other areas to be 
pursued in the commercial arena 
without penalizing the student who 
merely wants to learn about com¬ 
puters and figure out a niftier way to 
catch those elusive Klingons! 

Dick Wilcox 
Tustin CA 

You sure have some refreshing ideas, 
Dick, I've seen a number of significant 
contributions made by professional 
hardware and software people and it's 
nice to know that the "sharing" phil¬ 
osophy is still alive and well. 

We'll certainly be looking forward 
to your article describing that 16-bit 
system in an upcoming issue of Kilo- 
baud. — John . 


6100 Anyone? 


I would like to see some detailed 
discussions and/or comments on the 
Intersil 6100 microprocessor (PDP-8 
equivalent) as featured in Ohio Scien¬ 
tific Instruments 400 system (config¬ 
ured as a PDP-8 emulator). I'm going 
to build a PDP-8 emulator machine in 
the near future, and would like to see 
comments on OSI’s complete 400 
systems - they look good (to me, 
anyway — inexpensive). Software for 
the PDP-8 is easily purchased, and 
most important, there is an ocean of 
inexpensive PDP-8 software available. 

James E. Fletcher 
Parkersburg WV 26101 
There are probably a lot of people out 
there who would like to hear about 
systems built around the 6100 
(whether it's OS/’s, or someone 
efse's). If you’re building one (yes, 
you ... out there) then how about 
keeping notes on the problems and 
successes you encounter with the 
thing and do a write-up on it? And\ is 
this emulation of the PDP-8 all it's 
cracked up to be? Who has built a 
6100 system and actually taken PDP-8 
programs (on paper tape, for exam¬ 
ple), loaded them into the machine, 
and run them? /, and a lot of other 
folks (like Jim up there), would tike 
to hear about it. Okay? - John. 


Kilobaud — An Interface 


I have recently received two issues 
of 73 Magazine and found both of 
them very good, informative and at a 
level I could understand. If Kilobaud 
follows this same format, it will be an 
excellent magazine. 

I'm interested in radio-teletype 
from a computer hobbyist standpoint. 
The computer system I'm currently 
trying to set up and run is an 
Altair 8800 with an SWTPC TVT-II, 
PTC 3P+S interface board, 4K memo¬ 
ry, PerCom CI-810 cassette interface, 
surplus printer and other odds and 
ends. I need a magazine such as 
Kilobaud to help me interface every- 

continued on page 67 
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Mu- Corn pi eat Computer, 

Ocnnif Van Tassd, 

Science Research Associates, 

1540 Page Mill Rd., 

Palo Alto, CA, 1976, 

$5.95,9"xl2*\ 216 pages. 

This nicety produced book is a 
tasty collection of news articles, car- 
toons, fiction, poetry, full color 
reprints of early science fiction maga¬ 
zine covers, thought provoking 
articles, and exicftsive references to 
other literature. The carefully con¬ 
ceived goal is to get you thinking 
about the Big Picture how com¬ 
puters fit into our society and our 
day-to-day lives. 

The Chapter titles give a feeling for 
the coverage 

tn the Beginning; How Computers 
Oo It; The Software; The Present and 
Potential; Applications; Governmental 
Uses; The Impact; Controls, or Maybe 
Lack of Controls; Your Future. 

Put this hook on a coffee table, 
bedside table, nr any "heavy traffic" 
area so people can grab it and read it 
in little spurts. It's informative in an 
entertaining way, and people will keep 
coming back for more. 

Rich Didday 
Santa Cruz CA 95062 

WRITING AT WORK: 

00s, DON'T*, and HOW TOs 
By Ernst Jacobi 

Published by Hayden Book Co., Inc. 
Price: $6,85 
198 pages, soft bound 

Don’I you want to make extra 
bucks to support your computer? 
Sure you do! Don't you have discov¬ 
eries to share with Phcllow Computer 
Phreaques? You bet you have! Then 
what's holding you back from writing 
art article that will earn money? Is it 
that you're just a bit timid about 
putting your thoughts on paper for 
everyone to see? We understand. So 
we've found help for those of you 
who are teetering on the brink of 
imparting your Mored-up knowledge, 
(is a book Ilia I tells in casy-to-under* 
stand, step-by-step terms how to write 
articles, news releases, product 
reports, and even interesting inter¬ 
office memos. Our interest of course 
is the help it offers for magazine 
article writing. 

At the outset, Jacobi stales that 
you, as a potential writer, probably 
already have a good command of the 
language* grammar, syntax, and vocab¬ 
ulary, He assumes that you have some¬ 
thing important to say. His goal is to 
"lorn writers into communicators." 
From the book's preface, his purpose; 
"Form without substance is meaning¬ 
less, Substance without form creates 
n cedi csv difficult I cs, Bu i if there mu st 
he a choice, there is no question but 
that in the long run the world will 
choose substance over form, interest 
over mere clarity. For whatever else 
you may have to offer as added 
inducements, to be effective your 
communication has to be interesting 

first and last. This is the major 
point t make in this book." 

Jacobi also discusses essential 
components of a well written piece by 


offering examples of extracted writ¬ 
ings for comparisons of good and bad 
form. The extractions are, in them¬ 
selves, interesting reading. We are 
given tricks that make it all seem so 
simple; the first, "Write it as you’d 
write a lelter to a friend." (Which 
would certainly apply to writing for 
Kilobaud,) Finding that to lie an aid 
on art article we were currently writ¬ 
ing, I checked our article continually 
against each new point the book 
offered. Each point was wdl stated 
and exemptified, making quite clear to 
me that there is certainly room for 
improvement in my own work. 

The first section of "DOs" includes 
"Woo your Reader", "Have a Point of 
View", "Select vour Point of Attack", 
and 15 other topics covered in 73 
pages. All arc i mere sting to read jnd 
were immediately helpful in my writ¬ 
ing. 

The "DGN'Ts" section dashes 
myths about writing that have been 
held dear for tiro long. For instance, 
"Don’t use surprise endings", which 
are great for novels and short stories, 
but have a negative effect on informa¬ 
tive articles. Don't use passive voice in 
your writing. The author encourages 
us to he informal (using words like 
"t") and demands that "I" take 
d i r ec t, but comfor table, rexpon si bit i ty 
for my words while talking to "you." 
I especially applaud Mr, Jacobi's 
discussion of the use of cliches and, 
without reiterating his arguments 
against their use, simply restate his 
advice: "Abandon them," 

Perhaps the section entitled "HOW 
TOs" is among the most valuable. 
"How to Persuade", "Why and How 
l o Pu rr c t lm ic * \ * Ho w 1 0 flit n die 51 a l is- 
ttes fables and Charts" and many 
more topics fall into categories cover¬ 
ing the finer points of writing for 
pub! [cat Ions, 

Ernst Jacobi uses a chatty and 
personable style, making this guide to 
communicative writing his own case in 
point, (Was that a cliche?) He follows 
his own advice by making the book 
lively, informative, and easy to read. 
Jacobi’s credentials include 25 years' 
experience with major corporations as 
a writer and editor, and as an instruc¬ 
tor in business communications. Now 
that I’ve found it, the chances are I'll 
keep this book at my right elbow 
whenever I write an article. 

Sheila Clarke 
Glendale CA 91206 

A Computer Perspective, 

(The Office of) Charles and 
Ray Eamcs, Harvard 
University Press, 1973, 
$I5 h 9"x 9", 175 pages. 

This extended photo essay makes 
the history of computing come alive. 
Every page is covered with photo¬ 
graphs of founding fathers and 
mothers, their inventions, their private 
notes and letters. 


The coverage begins with Charles 
Babbage and his "Great Calculating 
Engine" and runs chronologically up 
to the delivery of the first commer¬ 
cially available digital computer, the 
UNIVAC, in 1951. Along the way are 
literally hundreds of fascinating 
tidbits, bizarre machines, the fossil 
traces of an incredible technological 
evolution. 

For me, the snapshot (p. 133} of 
Golds tine and Eckert, beaming like 
proud papas as they hold a memory 
unit from the ENtAC, is worth the 
price of the book itself, fhe thing is 
wider than the two of them, looks to 
be about a foot high - and stored one 
decimal digit! 

I found this book utterly fascin¬ 
ating, Not only couldn't I put it down 
until I'd finished it, but after two 
weeks I still found myself flipping 
back through it, amazed. 

Rich Didday 

8080 Programming For Logic IX-sign 
Adam Osborne and Associates, Inc, 
P.O, Box 2036, Berkeley CA 947Q2 
$7.50 (paperback) 

In the commercial/industrial world 
we find that engineers are quite often 
using microprocessors fur entirely dif¬ 
ferent purposes than the owners of 
personal computer systems These 
engineers are usually putting the 
micro to work in "dedicated con¬ 
troller" applications and/or as a 
substitute for logic circuitry. Some of 
their techniques and approaches to 
problems will undoubtedly be of some 
help to hobbyists doing similar design 
work. In the years (and months) to 
come we’re going to see more and 
more hobbyists developing interfaces 
using microprocessors instead of logic 
dements. 

The premise of this hook, which it 
shares with some other recent vol¬ 
umes, is that special purpose assem¬ 
blies of logic elements can be replaced 
by general purpose microcomputers 
with appropriate software and some 
minor amount of special purpose 
hardware. This particular book deals 
only with the SQ8Q processor hut it 
docs so in considerable depth and 
with a very detailed presentation of 
basic concepts using illustrative exam¬ 
ples. 

The first topic deals with the means 
by which a microcomputer can 
perform the functions of individual 
logic elements. This discussion starts 
with a description of how the 8080 
can simulate the operation of a simple 
tpgic inverter and proceeds ihrougb 
consideration of progressively more 
complex elements: a variety of gates, 
different types of flip-flops, one-shots, 
etc. Each element is analyzed in 
extensive detail, and the reader is 
given some appreciation of both the 
hardware and software aspects of the 
particular 8080 processes involved in 


simulating that specific logic device. 
Numerous illustrations are a great help 
in following the text. 

The next section considers the 
application of these logic processes to 
a specific example, the print wheel 
control logic for an actual printer. 
First the operational requirements of 
the control logic are defined and the 
implementation of the control logic 
with conventional IC logic dements is 
presented. This logic assembly is then 
converted to 8080 implementation on 
a une-for-one basis, the computer 
performing a specific operation (or 
operations) to replace each logic de¬ 
ment, This is clearly an unrealistic 
approach to design, no matter how 
instructive. The following chapter 
acknowledges this fact and Starrs over, 
taking a different approach. Beginning 
again with the operational specifica¬ 
tion and the necessary input and 
output signals, the print wheel logic is 
redesigned, considering only the best 
use of the microcomputer capability 
and ignoring the implementation with 
discrete logic elements. These chapters 
arc most effective. In going through 
1 he complete design process from 
three different approaches the reader 
comes to a solid understanding of the 
problem and is therefore better able 
to appreciate the solutions. 

The next chapters deal exclusively 
with software. First the print wheel 
conli ol software derived in the pre¬ 
ceding chapter is examined. Some 
more sophisticated programming tech* 
niques are introduced and the effec¬ 
tiveness of these techniques is 
demonstrated by improvements in the 
print wheel control program. The 
concluding chapters examine the 8080 
instruction set and some commonly 
required subroutines. Like the rest of 
the book, these chapters are exhaus¬ 
tively thorough and generously illus¬ 
trated. These chapters would be useful 
by themselves as instructional and 
reference material. 

In general, this is an excellent book 
for the reader who is willing to dig 
very deeply into the subject, It is 
painstakingly thorough and the reader 
willing to take those pains should end 
up with a solid understanding of many 
useful concepts and techniques. 

There are two objections to the 
book. The first and most obvious is 
the format of the printing. The author 
uses boldface and tight face type to 
distraction. In theory the light face 
type only expands on the material 
printed in boldface. As a practical 
matter, however, the reader is advised 
lu read all of the text. It will require 
mote time and greater concentration 
bul this will be repaid by better 
understanding of the material and 
therefore greater retention. In addi¬ 
tion, it will pul to rest the nagging 
suspicion that you*re missing some¬ 
thing important in all those para* 
graphs of light face type. 

The second object ion is the use of 
only a single application example. 
Having established a very firm founda¬ 
tion with the analysis of the print 

con! tinted ott pujpf 19 
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Rich Didday 
1218 Broadway 
Santa Cruz CA 95062 


Rich's "Lookahead" forum is art invitation to you, the reader, to submit 
material ranging from letters to news clippings to one page articles on the 
impact personal computer systems fund related items) tire going to have on 
society. Aside from doing some fine writing for 73 Magazine in the past (you 
ready should catch his three-part series on BASIC programming techniques), he 
also writes for Matrix Publishing. Be on the lookout for his new book, entitled 
"128 Q & A About Home Computers/* 

// ready must share a neat story about Rich with you (I'm sure there s a good 
moral here, too). When Rich finally made his decision as to which home 
computer system he wanted, he sat down and wrote the check, mailed it off, 
and then began the long wail. And he waited , . . and waited ... and waited. 
Eventually he got around to writing a couple of friendly reminders, but he 
finally had to resort to a very nasty letter. The fetter worked, and a few days 
later he received a refund check in full. Now, here's the good part.,. Matrix 
Publishing agreed to fix him up with a computer (and it turned out to be the 
same one he had been trying to buy). Sure enough, he received the computer 
from the company he had been threatening the same day he got his refund 
check from them!/ John. 


WHAT'S GOING ON HERE? 

The home computer idea, move¬ 
ment, revolution, avalanche is upon 
us. It f s get ling bigger day by day, hour 
by hour, microsecond by micro¬ 
second. It's the modern media world 
of microminiaturized, hypercybcr- 
nated, kilobaud, megabyte* electronic 
wizardry, and you don't want lo be 
found wanting when the com¬ 
puterized future comes knock, knock, 
knocking on your door. The future is 
here now! In fact, you just missed it! 
Your skill, youi equipment, and your 
psyche are all out of date. Catch up! 
Get new equipment! The information 
explosion will inundate you if you 
don'i get on the stick right now, 
Hurry, hurry, hurry! The onrush of 
progress is expanding exponentially, 
so get moving nose! 

But, on the other hand ... if you 
can stand aside quietly for just a little 
while and keep your head (perhaps 
chanting "But What Am I Going To 
Do With It?"), pretty soon your heart¬ 
beat and breathing will return to 
normal, and maybe you can start to 
see i! all as a colorful carnival, thrash¬ 
ing and flailing its own merry way 
into (lie future. Can't you just seethe 
advance men, the barkers, the promo 
crew making up leaflets and throwing 
them to the crowd on the run? And 
look! There-a down dressed up as a 
robot has stopped to give an 1C chip 
to a little girl! But there's a more 
ominous note loo. Can you spot the 
technological storm troopers, the 
computer shock forces, the agenls of 
change. The carnival is sending little 
jolts through the crowd as it passes. 
As it pulls out of sight and the sound 
of the drums gels softer and softer, 
the crowd si arts to break up, some¬ 


how a little different than when they 
came, wondering what has happened. 

Bui on the third hand (bet you 
wish you had one), you wouldn't be 
reading this,and I wouldn't be writing 
it if we weren't in both places at once; 
both in the carnival and in the crowd 
- embused and fascinated by com¬ 
puting, bnl h at the same time, mem¬ 


bers of a society that is being changed, 
perhaps in ways we don't understand, 
by what we’te doing. 

Our society is going to be different 
because of what we do. But how is it 
going In be different? Are there alter¬ 
natives that we, as a society, should he 
talking about and consciously con¬ 
sidering before it’s too late? Is there 
any hope that we can do something 
meaningful, useful? There must be a 
few dues a round that we can uncover. 
After all, this isn't the first time a 
new, broadly applicable, radically 
different tool has started to catch on. 
It’s certainly not the first time that a 
new leclmotogy has Infiltrated an 
unsuspec ting society. 

But then, maybe the reason our 
sex. iet y has been so unsuccessful at 
anticipating the real consequences of 
new technologies is that its just too 
difficult. Imagine standing beside the 
assembly line in Highland Park, Michi¬ 
gan- m 1914 as the first Model T came 
chugging off the assembly line. By 
wh.it sort of clairvoyance could you 
have imagined interstate highways, 
drive-in movies, shopping centers, 
teenagers making out in back seats, 
suburbs, smog, Los Angeles? 

But wait. Maybe if you were 


careful, kept asking yourself "What if 
everybody did it?" watched for 
trends, watched what people actually 
did with their cars* talked to city 
planners, car builders* and owners, 
then maybe, just maybe, you would 
have been able to piece together what 
was happening. At least enough to pul 
up a respectahle fight at a parly when 
someone started babbling about how 
nice it would be to get the streetcars 
out of the city because it was so 
unpleasant to drive over the tracks. 

This isn't the first time that .in 
advance in electronics has spawned a 
new species of smaller, cheaper digital 
computers. Computer “revolutions" 
have swept through the corporate and 
governmental subsocielies at least 
three limes before (the first genera 
lion, IBM 360's, minicomputers). 
Surely we can learn something from 
Ihose experiences. 

So there is hope, [f we act now, W'e 
can become a sort of distant early 
warning system. If we alert ourselves, 
sensitize ourselves to the impending 
changes, and share our observations 
with one another, we'll at least be able 
to watch things unfold. And maybe 
we’ll be able to see warnings of 
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unwanted change* ... before it's too 
late. 

If you want to get involved, what 
can you do? Lots. First of all, let’s 
make this forum sene as a communi¬ 
cations medium, make it work for alt 
of us. Send in your ideas, suggestions, 
complaints. Send in a news dipping, a 
note, or even a whole magazine page 
on a subject of interest to you . , , and 
the readers, 

If you have some special expertise 
or interest, use it to give us a report 
from that point of view. For instance, 
if you have a background in 
economic* or budget analysis, you 
could work out some rough estimates 
of the impact of home computers on 
the economy under a range of assump¬ 
tions what if they become as 
popular as microwave ovens ... stereo 
equipment... television? 

If you are on one side for the 
other) of the law enforcement 
business, let us know of any new r ways 
organized crime is using computer 
technology. And of course, there's the 
whole invasion of privacy can of 
worms. 

If you work for a company that 
uses or makes compute? equipment, 
spend a few lunch hours talking with 
people from different departments. 
We need to know what management, 
marketing, production, and research 
people think, fed, and plan to do 


about computing. Surely each group 
has a different perspective. 

If you are on friendly terms with 
your local school, why not conduct a 
survey? Find out how student atti* 
ttides about computers, calculators, 
electronic games, and media differ 
from those of teachers and parents. 
Could it be that children really are 
learning more from TV than the class¬ 
room? Can you test that idea? 

If questions about the societal 
effects of home computers come up in 
a bull session, jot down the various 
points made, and send them in. Let us 
share your ideas. Don’t let your brain¬ 
storms be forgotten. 

If you watch a lot of TV, keep a 
pad of paper near by and jot down 
references to computers, robots, elec¬ 
tronic technology, etc. A well done 
TV diary, giving show-, time, incident* 
and your ongoing analysis of the 
altitudes and assumptions revealed in 
each instance, would make a great 
Lookahead contribution. 

If you like to hang out in pool 
ha Us, bars, and penny arcades, see if 
you can get the management to give 
you figures on which games are 
getting the most plays? Try to get a 
feeling for what draws people to 
specific games. Play a number of 
games on ihe old style machines and 
then on the newer computer driven 
ones. Tell us how you see the differ¬ 


ence. How do you fed after winning 
or losing at Quick Draw or laws? 

How about a collection of com¬ 
puter oriented graffiti! It seems that 
the most dynamic, active, and influen¬ 
tial companies, colleges, and computer 
centers are the ones with the best 
bathroom wall philosophers. And 
graffiti seems to be a real outlet for 
people’s feelings and fears. 11 Why look 
up here? The joke is in your com¬ 
puter," 

If you read a lot of science fiction, 
keep us abreast of new ideas there. A 
side note; It. seems to me that virtu¬ 
ally alt sci-fi treatments of computers 
to date have been off base. They all 
suffer from the monolithic, central¬ 
ized super-computer madness of the 
sixties. Isn’t it obvious that what 
we’ic facing today is a society which 
has an abundance of computer power 
distributed widely throughout it 
rather than centralized in one god-like 
super-computer? Seems to me that a 
more reasonable model of computing 
in the future is the anthill or the 
beehive, not jehovah. 

One note of moderation: I think we 
should slay away from trying to guess 
what specific pieces of hardware are 
going to be available in the next few 
years. The manufacturers will do their 
best to keep us well informed of that. 

After wc*ve seen a number of 
changes being brought about by the 


infusion of computer power into our 
day*1 o-day lives* well be able to 
construct a number of different plau¬ 
sible futures and different scenarios. 
(And of course* well want to keep 
close tabs on how we and our friends 
are learning to use home computers 
by reading the rest of the magazine!) 
Then well be in a position to put new' 
developments in perspective and to 
suggest alternatives. But first we need 
the raw data, a collection of facts and 
observations from different points of 
view. Let’s get started! 

Due to the various lime delays in 
the system, letters you write now 
probably won't show up here until 
two issues from now. But please keep 
sending your thoughts in, even if to 
say that you don’t agree with my 
proposal. 

Next month, I'll discuss some past 
predictions that have been advanced. 
The majority of them have turned out 
to be wrong, and it’s interesting to 
speculate on where they went astray. 

Meanwhile, let's keep our feet un 
the ground* and our eyes and cars 
wide open. 

Send correspondence to: 

Looking Ahead 
121B Broadway 
Santa Cruz CA 95062 
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tionics consist of two motor con¬ 
trol lets and one pen control. The 
inputv to llse controllers are latched 
and rcquitc only one TTL U.L so the 
system can be hooted directly to the 
I/O port of any microprocessor. 


range, but not the TTLP, For less than 
$10 (with options), the Sylvanhills 
model (originally designed as a dass- 
room aid) will indicate actual Is and 
Os through a seven segment LED 
display. 



The available output voltages, 
which range from 5 to 24 volts, allow 
the I. MMOL A series to be utilized for 
a wide range of solid state equipment 
applications, including logit systems* 
Instrumentation, and hifi. Although 
they are primarily intended to be used 
as fixed voltage icgulators* these 
devices can also be used with external 
components to obtain adjustable volt- 
ages and currents. 

With adequate heat sinking* the 
regulator can deliver up to tOQ mtll'i- 
amps of output current, but the 
inclusion of current limiting ensures 
the peak output current will remain at 
a safe level, Safe area protection for 
the output transistor is another 
feature which prevents the |C from 
overheating. This limits internal power 
dissipation and will cause a thermal 
shutdown circuit to take over if power 
dissipation exceeds the level allowable 
by the heat sinking provided. 

The LMI40LA, LM24QLA and 
LM34QLA are all available in the low 
profile metal TO-39 package, and the 
LM240LA and LM34QLA arc also 
available in plastic TO-92 packages. 
When ordered m lots of 100, the price 
uf the commercial version is $2-10. 
These devices are immediately avail- 
able from stock. For mure informa¬ 
tion, contact Dave Whetstone, 
National Semiconductor, 2900 Semi¬ 
conductor Dr., Santa Clara CA 95051. 
Phone; (408) 737-5000. 

Make Your Own Computer Con Trolled 
Plotting Device 1 

Sylvanhills is now offering do-it- 
yourself X-Y plotter that may be of 
interest to the computer hobbyist. As 
shown in the photo, the mechanical 
system comes completely assembled, 
aligned, and tested. The electronics 
are supplied in kit form. The elec- 


While Ihe interface electronics 
assembly is si i .light forward and can 
easily be accomplished in two to three 
hours, this kit is not recommended fur 
the beginner. Also* since the kit con¬ 
tains no software olher than assembly 
instructions and some basic sugges¬ 
tions. the user will need considerable 
expertise in programming. 

The kits range between $750 and 
$895. Ancillary equipment is also 
available. For more information, 
please contact Allen Penn, President, 
Sylvanhills Laboratory, Inc.. T Sylvan- 
way, Box 239* Strafford MO 65757. 
phone; (417) 736-2664. 

Sylvanhills Laboratory TTLP Logic 
Probe 

Microcomputer hobbyists in need 
of a lust test instrument will undoubt¬ 
edly consider acquiring a logic probe. 
Most probes arc in the $50 plus price 


I he TTLP also features storage of 
fast negative-going signals. The whole 
package is mounted on an epuxy G-10 
double-sided, plated-through, printed 
circuit board. The TTLP has a sharp 
point lor digging into nodes, making it 
easy lo penetrate corrosion. Logic 0 
thresholds axe from 0 lo 0,8 V* Logic 
1 thresholds from 2.2 to 5 V. Maxi¬ 
mum voltage on the standard version 
is 5 V. with an option available to 
provide overvoltage protection up to 
* 25 volts. 

It is important however, to keep 
the 1 ILP’s limitations in perspective. 
Since a dock pulse alternates between 
0 and 1 on the seven segment LED, it 
appears as a zero with a low intensity. 
If the signal is a low-going high pulse, 
the zero indication on the LED will 
not dissipate fast enough lo show the 
pulse. One way to get around this 
deficiency is to check the signal 
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was getting $10.20 after royalty to 
the author. Subtract another $1.20 
for the manufacturer's representative 
who sells the programs to the com¬ 
puter stores, sets up the displays* 
follows up on problems and collec¬ 
tions, and makes sure that the stores 
have a good stock uf the latest pro¬ 
grams as well as that the salesmen 
understand what the programs will or 
won't do. 

Each program has to be checked 
and rechecked before publication, the 
documentation has to be written and 
published, die sales package has lobe 
designed and printed. Computer tape¬ 


rs not cheap it will probably run 
around $4 a cassette for tested tape. 
Once duplicated (have you seen what 
tup quality duplicating machines 
cost?) each tape will have to be 
checked by a computer to make sure 
every last bit is okay. Then comes the 
advertising and sales campaign 
inventory shipping — billing 
collections sales managers the 
works plus overhead, and even a 
modicum of profit. 

So muc h I nr programs ... I got 
carried away. 

I'm hoping that well be able to 
have enough programs and info in 
Kilobaud so there will be no need fur 
user groups of the various systems. 

There is one more major thrust for 
Kilobaud, and this has to do with that 
small business market I mentioned 
b e ft>rc, 1 h is is a ca l ego rizati on * r eal I y, 
for it also includes home computers 


and school computers ... all of the 
uses to which wx expect small com¬ 
puter systems to be pul. I figure that 
this is going to work out at least as 
well as the projections made for 4 
perhaps 5000 computer stores each 
doing an average of $500,000 per year 

some larger, many smaller. I'll be 
surprised if most of these businesses 
aren't run by ex-hobbyists. In A7fo- 
baud I'll try to help all 1 can not only 
Lo make the computer hobby fun but 
also to show how it can be used to 
make money. One little hint that 
works for you will be worth many 
times a Lifetime Subscription cost. 

So there are my aims — we'll see 
what happens and please remember 
that Kilobaud is a medium for you to 
communicate with other hobbyists. 
The more we help each other, the 
better off everyone will be. 

One commercial factor - it is the 


through an inverter. 

The prime selling point of the 
TTLP is ihe fact it is inexpensive. Ihe 
device will give you an indication of 
what's happening in your system, 
although it lacks all the functions of a 
full logic probe. For more informa¬ 
tion, contact Model TTLP Logic 
Probe, Sylvanhills Lab. Inc., Sylvan¬ 
way, Box 239, Strafford MO 65756* 

TYCON'v 8080 Development Soft¬ 
ware 

New software development pack¬ 
ages fur 8080 type microcomputers 
(and priced for the hobbyist) are now 
available from Tychon. Tychon's 
Editor (TED), Assembler (IAS), and 
D-BUG programs can be run in micro¬ 
computers with at least 4K of read/ 
write memory. Programs arc available 
on paper tape nr In 1 7G2A or 2708 
type PROMs. Each software package 
includes complete documentation on 
its live and information about changes 
for different I/O formats. Listings fur 
each program are also available. 

Pm.es for ihe software arc as fol¬ 
lows Editor/Assembler tape - $25; 
Edit or/Assembler listing $40; 
D-BUG tape - $ 10; D-BUG listing 
$40; Due u m en l at i on pat ka ge $ 5; 

and delivery is within 10 days. For 
further information, contact ), A, 
Titus or G. II. Wilson at Tychon, Inc,, 
PO Box 242, Blacksburg VA 24060, 
Phone; (703J-951-9030. 

New Video Game Chip From Naimn.il 

National Semiconductor Cunsumer 
Products Division has received FCC 
approval for its TV game* "‘Adver¬ 
sary" which employs the MM57100 
video game logic circuit and LM1839 
video modulator. 

"Adversary'" (suggested retail - 
$99) features a choice of three play ing 
fields: tennis, ice hockey, or handball. 

For more information, contact 
Gcorgene H. Berglund, Public Rela¬ 
tions, Consumer Products Division, 
1177 Kern Ave., Sunnyvale CA 
94086 ■ 


advertising that pays for a magazine to 
be published* nut the subscriptions or 
counter sales. This means that the 
more you let advertisers know that 
you are getting their message, the 
bigger and better your magazine will 
be. Send for their literature and let 
them know when you buy something 
that Kitolwud helped the sale. If you 
do this you'll have as fat a magazine as 
the hams have in 73 and your main 
problem will he finding enough time 
to read all of the articles. 

Hopefully you'll be taking enough 
advantage of the money-making 
schemes in Kilobaud to buy all of the 
equipment you have time to use - or 
at least youll be writing articles which 
wilt get you money For hardware. You 
have an opportunity unparalleled in 
history lo make money from your 
hobby don't ignore that insistent 
knocking at your door.* 
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Dick Whipple - John Arnold 
505 Clemson Drive 
Tyler TX 75701 


Recognizing the popularity of 
BASIC as a programming language 
among compute; hobbyists, the editor 
of Kilobaud suggested that we create 
The BASIC Forum, As the name 
implies, our effort will be to provide a 
medium for the exchange of ideas on 
BASIC. As authors, our responsibility 
will be mainly to compile and edit 
information provided by readers and 
other sources. Publication of The 
BASIC Forum on a continuing basis 
will depend, to a great extent, on the 
interest and response shown by read 
ers. 

Operation of The BASIC Forum is 
best explained by the diagram of Fig, 
1. Ai point A, the authors (Dick 
Whipple and John Arnold) will receive 
input data from Kilobaud readers, 
commercial software suppliers, and 
any other good sources which devel 


op. We will edit and condense the 
material for publication in Kilobaud 
under the title "BASIC FORUM" 
(point B of Fig. 1). Kilobaud will then 
move to the readers via link C The 
readers at point D will then have an 
opportunity to consider the various 
ideas put forth From the readers, two 
potential paths can develop: (I) from 
reader to reader (Path E), and {2) 
from reader via link F back to the 
authors at point A. In this way, two 
continuous information loops wilt be 
established. If no glitches spoil the 
system, a significant idea exchange is 
possible. 

To bring the system up from a 
"cold start," may we suggest some 
possible reader input. This may con 
sist of one or more of the following 
data types: 

1. Questions about BASIC and 


Fig. I 

Flowchart 

The BASIC Forum 



about programs written in 
BASIC, 

2 + Comments and suggestions 
regarding the use of BASIC in 
applications involving business, 
industry, education and recrea 
tion (games). Note: The order is 
not significant' 

3, Information concerning the 
availability of BASIC system 
software and application pro 
grams. 

4, Reports of problems and 
errors encountered in the use of 
BASIC software and programs. 

5, Requests for assistance (or 
offers to help) in developing 
specific applications programs 
(part of the reader threader 
loop). 

Upon receipt of this dJU, the authors 
will sort and organize the material for 
presentation in future issues of Kilo¬ 
baud. Every effort will be made to 
fairly evaluate the data and we will iry 
lo publish as much as practicable. 
From time to time we will Introduce 
topics concerning BASIC to help 
stimulate reader interest, 

To get the system initialized and 
off to a good start, we submit the 
foltowing topic for your considera¬ 


tion: The need for BASIC language 
standardization has been under serious 
discussion lately. Even now efforts 
are being made to bring the same 
standardization to SASIC that exists 
with FORTRAN and other high level 
languages. To what extent (if artyj 
does, imposing such standardization 
influence creativity in the program¬ 
ming field? There is little doubt that 
such standardization produces better 
program exchange potential, but is 
this at the expense of experimentation 
and diversity in programming? Let's 
get your ideas!! 

Material for BASIC FORUM should 
be addressed lo: 

The BASIC Forum 
c/o Dick Whipple 
305 Ctemson Drive 
Tyler TX 75701 

If you wish to have any material 
returned, please include a stamped, 
self addressed envelope. All items 
published will be properly aeknowF 
edged according to source. If you 
desire to enter the reader Lo reader 
loop, let us know and well publish 
your address as well. 

Our RESET switch has been 
thrown we are now entering a data 
entry mode. Start your data flow! ■ 
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Around the Industry 

Wayne Green 


THE NOBBY COMPUTER INDUSTRY 

Jf you read many of the profes¬ 
sional computer magazines, you 
probably realize how small the hobby 
pari of the microcomputer industry is 
■■Iv compared to the professional end 
and the two are quite separate tn 
many ways. 

In order to keep in touch with what 
is really happening in our microcosm 
I’ve been getting around to visit most 
of the major firms supplying equip' 
merit to the hobbyists; and I thought 
you might like to know what Cvc 
been able to discover. 

My first trip around was in August 
1975 when I visited Sphere, MITS and 
Southwest Tech, These were all there 
were to visit at that time, t talked 
quite a length with the lliree and 
reported this trip in 73 (Feb. 76. page 
86), It seemed appropriate to make 
another gp-arotind in August 1976 for 
a follow-up on Sphere, MITS and 
Southwest Tech, plus a visit to new¬ 
comer firms such as jolt, Apple, 
R ( Imsai, Wave Mate, Morrow, 
Godhout, and Intelligent Systems. 

|OLT 

Though the [oil system has not 
been advertised much recently, it was 
one of the first €502 based systems 
and, from what I had Seen at hamfest 
demons! rations, was a very cleverly 
designed microcomputer. We (Sherry, 
the marketing manager and i) dropped 
by to talk with Ray Holt and Manny 
Lemas. Ray is the engineering end of 
the business and he showed us the Jolt 
computer and their plant. 

The plant is a small one - most of 
it in one large room, and I didn’t see 



/he foil 6502 CPU kit. 



the foil work area where kits arc 
packed for shipping. 


any signs of high volume business, so I 
suspect that the lack of advertising has 
slowed things duwn. Ray showed us 
the loll system, including his new 
SOSOA CPU and video tape controller, 
l he designs look vet y good, hut l 
suspect that there probably has been a 
giKid deal of resistance to the lack of a 
cabinet and to the mechanical design, 
which is more reminiscent of labora¬ 
tory equipment than a computer. The 
fact is, as more and more manufac¬ 
turer are finding out, the design of 
the cabinet and front panel are of 
critical importance in sales this is 
show biz more than engineering. 

Ihe jolt kits are very nicely pack¬ 
aged on foam sheets. The boards are 
lop quality. They have the CPU card, 
a 4K RAM card, an I/O card, a power 
supply card, and a IK assembler 
which comes on PROMs. The video 
tape controller system keeps track of 
any place on a tape and returns to it 
at the touch of a button. It also 
responds to answeis a student pro¬ 
vides to questions on video tape and 
returns the tape to a programmed 
frame if the answer is not right- It 
appears to be a great compliment to 
video tape teaching systems. 

Much of Ray's and Manny's efforts 
are going into their Microcomputer 
Digest, a monthly newsletter aimed at 
the professional side of the microcom¬ 
puter industry. At $28 per year this 
newsletter is not very attractive to 
hobbyists, but should find acceptance 
within the OEM part of the industry. 

Mow, about that mechanical design 

the individual boards are stacked 
one on the other with metal spacers in 
the four corners to hold them apart. It 
makes a compact square computer, 
but l can see where servicing c chi Id be 
frustrating for there is no simple way 
to unstack the boards so you can 
reach in and check individual IQ* or 
swap them, 

[ here’s much to be said for the 
plug in card system, complete with an 
e si lender board for testing and service. 
They may be doing well enough with 
industrial orders, bill if they do decide 
to go after ihe growing hobby market, 
a nice cabinet and plug-in cards would 
help a lot in competition with other 
systems now available. 

IMSAI 

Our next visit w^as to the new Imsai 
plant in San Leandro where we had a 
chance to talk with Fd Faber. Ed said 
lliey were getting ready lo move loan 
even larger building and declined lo 
let me see I licit present plant or lake 
any pictures. Maybe next trip. 

GODBOUI 

Having been to visit quite a lew 
surplus dealers, the mountains of Stuff 


at God bout's didn't surprise me* A 
closer look a I some of the boxes made 
more of an impression .. * for one was 
a large box full of plastic tubes, each 
packed with 8030A chips .. . another 
box was full of 6800s .. . But shelf 
over there was piled vvilh boxes of 
RAM memory chips ... the next shelf 
with PROM chips, and so it went! 



/fere's ltiff Godhout, fust in case you 
have the idea a!I tni/honattv business* 
men dress in pin stripes, How he 
provides the fantastic service he does 
from the mountains of parts is one of 
the wonders of the world yet 
readers are constantly writing tn com- 
pHmentlng BUL Sot a gripe in a 
carload. 



Godhout coufd probably use a com¬ 
puter juft to keep track of the tiff forts 
of parts tinti chips he has around One 
of the boxes on the /tdi has about a 
thousand at the newest, tastest, hot¬ 
test SOSOAs ... 

After going through several rooms 
full of equipment and pans, we came 
to one with a table and a text setup of 
God bout's new PACE computer 
system. I gather that this system has 
been undergoing constant update 
modifications while Bill Gudboul has 
been trying to get film commitments 
on chip deliveries to support it. Once 
he has everything either on hand or 
definitely coming down the pipeline, 
he plans tn start releasing I lie system 
... a very well designed and sup¬ 
ported 1 fvbit microcomputer. 

We all shove over lo visit George 
Moirow and see how be was coming 
along with his stuff ♦ ♦. a boot panel 
for Ihe Alt air/Imsai systems , an 


operating system, mom lot, debugger, 
and so forth for the Godbuul PACE 
„ , . and a lot more projects. George is 
one of those people with super energy 

— full of ideas — unable to sit still for 
a minute talking enthusiastically 
about this and then That - mme ideas 

— then off to work on six to twelve 
different pr ojcCts simultaneously. 

Bill and Reo {Reo Pratt, who works 
for Bill pilots Bill's planes writes 
art ides for Kilobaud ) managed to talk 
George into coming with us for din¬ 
ner. While you and l might think it a 
big deal to drive 25 mites or hj for a 
good dinner, our group went hack to 
the airport at Oakland and flew about 
a half hour lo gel dinner. George 
talked animatedly during the flight op 
and back and all through dinner . .. 
we had to move the glassware back lo 
keep him from sweeping it uff the 
table as Ire waved his arms to illustrate 
points every now and ihen. Not that 
anyone discouraged him in any way, 
for his ideas were always interesting 
and provocative. I sure wish he'd 
write. 



George demonstrated the debugger 
program he has in his front panels, ft 
certainty is flexible. 



/ 


fhis is the PACE kit which George has 
designed for Godhout. The lower 
board is the front panel hoard. 
George's front panel replacement for 
the Aiiatr is meeting with success 
since ft contains excellent soft and 
firmware. 


1G 
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A few hours with George Morrow is 
art experience. This genius is coming 
up wtih great idem several times an 
hour, it would take a lug plant and 
thousands of people to keep up with 
his creativity. George does the design 
work for GodbOdt and tor his own 
Morrow's Micro Stuff. 


APPLE 

A small ad had appeared for the 
Apple computet so we drove up to see 
what I Ids was about. We met Steve 
Jobs ntnd his partner Steve Wosniak, 
wliu have developed a first rale com¬ 
puter system in one comer of the 
JobS garage. Jobs did most of the 
hardware and Wbfniak has done the 
operating system, No* bad for a pair 
of 20-year-olds. I was quite impressed 
by the thinking that went into the 
Apple . .. the whole computer and 
video generator is on one board, with 
a very smalt cassette interface board 
which plugs into 1 he main board. It is 
simple, ye* elegant. 

When you consider all of the engi¬ 
neering that goes into a computer, the 
fellows have done a Fantastic fob. Now 
they are getting into serious produc¬ 
tion signing up dealers and they 
will have their hands full 



This is the Apple computer naming a 
game of Life the small board 
staking up at the tight is the cassette 
interface! 


M&R ASTRAL 2000 
Not far from the Apple ** pi ant” we 
visited the MAR firm where they were 
putting the finishing touches on a 
most interesting system, h is purlieu- 
I a rly well designed mechanically, with 
cards which slide in solid guides plug¬ 
ging into a mother hoard which is Just 
hack of the from panel of the system. 
The front panel plugs into the mother 
hoard, making a very solid mechanical 
arrangement, This is one of the best 
mechanical systems I've seen yet. 

fhe sijrc of the individual cards is a 
hit smaller than I'm used to, but the 
chaps at MAR have those chips 
packed in solidly. The from panel 
mounts in a 19” wide cabinet, so 
there is no problem in expanding the 
system to accommodate a lot more 
cards with a second chassis which can 
mount right above the first. The 
power supply is very hefty and should 
handle a lot of cards. 

They were particularly proud of 
thdr software — you II be reading 
about it, It's an BK Basic with a tot of 
interesting features. Since there aren't 
all that many Basics lor the 5800, this 
wilt be most welcome. It comes with a 
Star Trek game and a newsletter lot 
S3S, 



Here'S the PACT CPU which should 
be aw if able soon from Godbout. 


WAVE MATE 

Dennis Brown has a nice plant 
down in Los Angeles where he turns 
out the Wave Mate systems. These are 
the only wire-wrapped computers in 
the hobbyist market, so we asked 
Dennis a lot of questions about that. 
I he answers w ere interesting, so we 
prevailed on him to write an article so 
you'd know the reasons for using this 
■more difficult type of construction. 

Wife-wrapping certainly is used to 
advantage in the Wave Mate ... all of 
ihe circuit boards are identical ... a 
design Dennis invented which permits 
almost any configuration you could 
want , One big plus with this system of 
building is that changes are a lot easier 
to make. Dennis has recently come up 
with a 280 based CPU. With most 
other systems you'd have to tty to sell 
or throw out your old CPU board and 
pul in a whole new one to go with the 
Z80 hut with the Wave Mate this 
merely means some wire changes - 
not a big deal. 

Dennis was working on an economy 
model of his system. The higher price 
of lire Wave Male has kept safes down, 
which is unfortunate, for in most of 
these things you get wh.it you pay for. 
tl you buy cheap you get cheap. Tor 
instance, as far as I know, Dennis is 
the only manufacturer who checks 


out each and every chip before 
sending il along for a Ml or assembled 
unit. While not more than a small 
percentage of chips are faulty, a two 
percent fall-out will give you a good 
chance of at least one bad chip in a 5D 
Chip system. It's difficult enough to 
tiuuhkshouL a system that you've had 
working, but trying to find a had chip 
in a new system is real bad news. 

COMPUTER MART 
We stopped off In Orange to see 
John I tenth and his Computer Mart 
operation, probably the largest com¬ 
puter store in the world. John was the 
one who made the good deal for the 
Lear Sicgler terminals which a lot of 
us are using. He was well along toward 
being able to market a 16-bit com¬ 
puter watch for announcements on 
this one. We got promises of several 
very good articles from them. Dick 
Wilcox slopped by at the right lime 
,md promised articles on monitors, 
operating systems, etc. 



The Sphere kin are furnished with 
every part dearly labeled and stuck 
into a ft sum sheet. Missing parts are 
immediately apparent with this simple 
system and it sure makes it easy to 
locate the rigid parts for the right 
hales on the boards. 



SPHERE 

From Los Angeles we flew up to 
Sail I Jke and an update on Sphere. 
Mike Wise, with whom I talked at 
length last year, had been replaced by 
a new president of the firm. I did get a 
chance to talk with Doug Nancey, 
who had been there the previous year, 
fhey’ve had a lot of problems getting 
delivery an parts and their plans for 
providing a good fast version of Basic 
had misfired. Doug was quite enthu¬ 
siastic about their new TPU board 
and they are making deliveries on 
their regular Sphere 680(1 based 
systems. 

Sherry was particularly happy to 
get to Salt Lake for it gave uv a chance 


to see her sister and have dinner with 
Sherry's son, Mat, and daughter, Abra. 
We + d had dinner with her other son, 
Roger, in Los Angeles. 

We managed a short get-together 
with the chaps who make those MPI 
printers and got a promise of an 
art icle from them. We have one of Ihe 
printers in the Kilobaud lab and it 
does a grand job. We were a little 
short of time so didn't get out to thdr 
plant. 

MITS! 

It would uke several pages Just to 
outline the many projects going full 
tilt at MITS these day>. Ed Roberts 
had cleared the day for us and we 
talked for hours on the hobby com¬ 
puter business, about the plans he had 
for further Altair products ... and 
about ham radio. Ed has gotten all 
fired up about getting active on ama¬ 
teur radio again and he had a tot of 
questions about that. This is not one 
of my weak spots. 


Dennis Ilrown, the designer i md presi¬ 
dent of Wave Mate. 


flow about this SK PROM hoard? 
Designed by George, available from 
Godbout. 



A lltson Martin, Dennis* super assistant 
who does much of the production 
work . 


This n one of those Waked Ram 
boards for a 6502 bated CPU 
system. 
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MfTS has a whole big building full of 
people working hard to turn out the 
A hairs. 


To give you an idea ol how enthu¬ 
siastic he is — not long a her I got back 
home, he got a Kenwood 820 trans¬ 
ceiver and a slow scan television mon¬ 
itor. Within a couple days he had an 
interface for the slow scan monitor so 
it would prim oul on a Teletype 
machine! Think of how much money 
hobbyists could make with an A It air 
system to print photograph from 4 
slow scan camera system! It should 
cost about 10% of what the present 
computer photo systems now cost 

Ed did not share my reservations 
about the problems of software for 
the Z8Q chip and explained that they 
were just about ready to announce a 
now Z80 CPU for the Allair. There's 
an article on this rn this issue. He 
doesn't think that rewriting the soft- 
ware for the Z8Q will take nearly as 
long as it did for the 6800. 

MITS is well settled inlu their new 
plant now and things seem to be 
moving along rapidly, with several 
programmers developing their disc 
operating system, Basic lor the /80. 
and updates on everything else. 
They're also working on some new 
low cost floppy systems and have 
some other ideas in prototype shape 
in the back rooms. It's nut likely that 
anyone else in the held is going to 
catch them sleeping. 


SOUTHWEST TECHNICAL 

PRODUCTS 

Last year when i visited Southwest, 
Gary Kay! the chief engineer, had a 
prototype of the SWTG80Q computer 
system going, with hopes fur delivery 
a lung in October or November. Now, 
several thousand kits later, with their 
system the largest selling of the 6800 
based computers, they were putting 
the finishing touches on details of 
their graphics package and their 
newly’announced $250 line printer 
kit. 

Dan Meyer, the president, look us 
all thiough their large plant their 
main business has been high fidelity 
audio kits for some years, but now the 
computer orders have been gaining 
rapidly. We saw the new printer work* 
with its 40 character printout on a 
kind of wide adding machine tape. 
This is line fur dumping programs and 
other such things which you might 
want to save. It's a bit restricting for 
writing letters but if you can make 
do with capital letters, a five by seven 
pin matrix prim of the letters* purple 
ink and naiiow paper, you're all set. 
The price is certainly right! 

They had their new casselie system 
running well lou and used it to load 
their graphics program. I'il surety have 
to get one each of those. Afu-r playing 
the tank games in the quarter arcades, 
I can’t wait until I am able to get one 
of them working for myself; and this 
graphics system looks like the way to 
go. 

We gin a short demo of ihc 4K 
Basic they have at present, and they 
promised &K would be available soon. 
They told the truth because I do at 
present have I heir 8K in hand. 

Thai evening Sherry and I drove 
□tit to visit her folks in Sc gum, just 
east of San Antonio. I've known them 
for a long time, but hadn’t seen them 
in over 15 years; so it was a great 
reunion, l love to cook and one of my 
favorite dishes is a curry I learned 
from Alma, Sherry’s mol her. She 
served it with about ten different 
condiments . . . like crushed pine¬ 
apple, chopped nuts, coconut, raisins* 
chopped egg. etc. Fantastic. 

MOTOROLA 

Since we weren’t far away* we 
stopped off for a few hums in Austin 
to visit 1 lie new Motorola l SI plant. 
We were given the red carpet treat¬ 
ment and gut 10 see them making LSI 
chips. I'm nut sure an article would 
really get tire idea across of (he 
magnitude of the equipment and the 
care needed to turn out these ICs. 
They glow the silicon crystals, then 
turn them on *1 lathe, slice them into 
thin slices, polish the slices, and then, 
step by step, deposit the layers of the 
transistors and circuits on these slices 
of siiicuii, each about 3“ or so in 
diameter. When they get through they 
cut the tiny |C chips up and check 
them. 

There are a lot of interesling ICs in 
the works - like 32K RAM chips and 
perhaps even a 64K RAM! One re¬ 
cently announced product 3s an inex¬ 


pensive digital voltmeter chip (DVM). 
This is really just an analog to digital 
converter, but it comes complete with 
the coding needed to produce num¬ 
bers on LED readouts. 

THE USS DRUM 

Since my old World War M sub¬ 
marine crew was holding a 3thh re¬ 
union at Mobile where our old boat is 
on display in Ihc Naval Museum there* 
tied up alongside the Alabama, we 
stopped otl there lor a day. All those 
youngsters who fought the war with 
me in the !940's are all old men! 
What a bummer. We had a great time- 
talking over the War and we have 
reason to be proud as we were on one 
of the top submarines in scoring. But 
we didn't talk much of ships sunk or 
prisoners taken, but rather our 
memories of a cook whose spaghetti 
fell off the stove and who was caught 
trying to put it back in the pot - the 
humorous anecdotes of the War, 

INTELLIGENT SYSTEMS 

Our last stop on the trip around the 
country was Atlanta to see the out lit 
making that epitome of color graphic 
terminals* the Intelligent Systems 
CRT terminal. 

We found the plant just on the 
out skirls of Atlanta and had a nice 
lour. I expected .1 bit more business 
than I saw perhaps we can help 
them gel the word around. Their ads 
give the impression that you can have 
a full color terminal for probably not 
a Jut more maybe even less than .1 
regular black and white terminal. 

The Intel color terminal is certainly 
reasonable, but as with any other 
computer system, you have to decide 
which accessories you really can't do 
without — and so many of Ihc alterna¬ 
tives available with this unit seem 
desirable that you can run the bill up 
pretty steep. T he system comes with 
an SQ80 processor built in - and this 
means that you have a lot more than a 
dumb terminal, you have a full com¬ 
puter, if you want to go that route. 



Terry Huey * president of Intelligent 
Systems. 


You can call up the letters in any 
color you want . . . and with one ol 
their confounded accessories you can 
have a background in one color and 



Some of the Intel Systems being run 
for test they arc checked for a w eek 
before being shipped. 



There's a lot in the box - this is the 
analog module, for example. 


the letters in another,.. it's gorgeous. 
Sure, it's a little larger than the black 
and white CRTs* but why not go full 
color? 

While the unit is pretty expensive 
by hobby standards, particularly if it 
us used just as a terminal* it may go 
well in commercial use once the in¬ 
dustry gets familiar with it. Well 
know more about that when wc have 
some programs available to run with ii 
— it could turn out to be a great home 
terminal unit and computer. 

We made a stop in the Computer 
Systermtcnler in Atlanta and had an 
interesting talk with the four chaps 
who are running it. They ate selling 
continued on page 24 



The computer Systemscenter has 
some eery good software available for 
business uses. 



Selling to business? Then you need a 
nice looking work station like this, 
complete with terminal, floppies, and 
printer. The Systemscenter has several 
good business programs available and 
they are working on a lot more. This 
may he a rery good model of what a 
computer store will look like by next 
year. 
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wheel control problem, the reader 
could then benefit from the chance to 
try these skills on some additional 
examples, even if treated briefly. 
Some cases involving more data 
manipulation and/or more complex 
input/output procedures would pro¬ 
vide a more complete picture of the 
8080 in the systems environment. 
However, the author may have felt, 
with some justification, that this went 
beyond his purpose of considering the 
8080 in logic design. This is a minor 
and personal objection and should not 
discourage anyone interested in Mr. 
Osborne's excellent book. 

A. H, McDonough 
El SegundoCA 90245 


The Best of Creative Computing, 
Volume 1, David H. Ahl (ed.); 
Creative Computing Press, Morristown, 
New Jersey, $8.95, paperback, 8ftx11, 
ix+317 pages. 

If you are a junior high or high 
school teacher with any inclination at 
all to teach about technology (doing 
it, using it, analyzing it, or living with 
it), and you haven’t seen 77?e Best of 
Creative Computing , please drop 
whatever you’re doing and go get this 
book. If you know of such a teacher, 
get him or her a copy, and make sure 
that it is read. 

But how about the rest of us? What 
does a volume, edited by a man whose 
long-term mission seems to be to 
inform, reform, and revitalize second¬ 
ary school teachers, their methods and 
curricula, offer to us? That is, what 
does this collection offer to people 
who want or have their own com¬ 
puters - who are interested in putting 
them to use in their daily lives, not in 
the classroom? 

Quite a bit, it turns out, but much 
of it is at a fairly high level (meaning 
remote from the hardware, remote 
from specific programming tech¬ 
niques). From the aspects of being 
informational, well-stocked with ideas 
to draw from, and entertaining, this 
volume is virtually unbeatable. Cer¬ 
tainly nothing in my local computer 
store has anything that can compare 
with The Best of Creative Computing 
in the softer, more human (as opposed 
to hardware) reaches of the computer 
world. 

There are seven main sections — let 
me cover them one by one. Since 
something about the book made me 
want to read it from the back, I’ll go 
through it in that order. 

On the back cover is the great R. 
Crumb "Don't you think it’s time to 
Stop Watching TV?" ad, remade (by 
the artist) into the "Creative Com - 
puling" ad you’ve no doubt also seen. 
(It originally appeared on the back of 
Motor City Comics, No. 2.) 

The last section in the volume 
contains reviews of over 70 books, 
many of which are of interest You 
may have to read between the lines to 
find what you’re looking for, but 


there is a lot of useful information 
here. 

The next to last section has the 
most to offer if your goal is discover¬ 
ing things to run on your machine. It’s 
called “Computer Games,” and it 
includes program listings (in various 
dialects of BASIC) for 17 games 
including two of the all time favorites. 
Hunt the Wumpus and Star Trek. One 
of the games (Geowar) is followed by 
a critique by Gregory Yob (creator of 
Hunt the Wumpus). It’s must reading 
for prospective game designers. In 
fact, the whole notion of reviewing 
and critiquing games and software in 
general is important. We should see 
more of it. 

The fifth section is “Programs, 
Puzzles, Problems, and Activities." 
Although most of the articles are 
aimed at students in a classroom 
setting, there are a lot of interesting 
ideas, projects, and an occasional 
program. There are a number of gentle 
mathematical topics, programs which 
help young users write poems and 
stories, several suggestions for attitude 
surveys, articles on simulations, a pro 
gram which can be used to study 
particles falling under gravity, and a 
program which can be used for word 
drill in a foreign language. All in all, a 
wide variety of fascinating topics, well 
presented. I wish Creative Computing 
had been around when 1 was in 
school! 

Before that you’ll find “People, 
Places and Things," which has a Whole 
Earth flavor to it. It includes an access 
to media section (the Compleat 
Computer Catalogue) which lists a 
number of relevant books, magazines, 
newsletters, etc. Well worth a look. 
You’re almost certain to find an 
intriguing title you never heard of 
before. There’s also a piece of prag¬ 
matic knowledge in this section - tips 
for winning at Pong 

“Foolishness" contains several 
humorous short articles and six full 
pages of comics. All are funny, 
although they all seem to have been 
done by people from the outside 
looking in on the computer world. 

The section called “Fiction and 
Poetry” contains three short stories 
and a page of poetry. The Isaac 
Asimov story “The life and times of 
Multivac” makes pleasant reading, 
although oddly enough it seems a 
little daied despite its 1975 copyright. 

The first and longest section in the 
book is “Articles and Commentary.” 
It covers a great variety of topics, 
many of great timeliness and many 
relevant to anyone who hopes to cope 
with our computerized society. Again, 
although much of the material is 
aimed at educators, there are lessons 
for all of us. For instance, the two 
articles on program portability (“The 
Parable of the Horse" and “Technical 
Transport Problems”) should be seen 
by anyone who is writing software 
they hope to share with others. The 
specific problems discussed may not 
be directly relevant to the home com¬ 
puter situation, but the general dif¬ 
ficulties and the solutions definitely 
are. 


Two Overall Impressions 

One thing that really grabbed me 
when I looked through this volume is 
the artwork. Virtually every page has 
some kind of nonverbal visual pattern 
on it, most of them very neatly tied to 
the ideas in the text matter. A fantas¬ 
tic job! And the artists! Not just R. 
Crumb, but other masters too - an 
absolutely incredible drawing by Bill 
Elder (p. 117), and several things by 
Will Eisner. The drawings, computer 
graphics, and photographs just don’t 
stop! Flipping through, I see page 
after page with well thought out 
graphs, cartoons, several fine pieces by 
George Beker, several derivative but 
well-executed drawings by the editor 
himself, a Gilbert Shelton, a Shary 
Flenniken, and, on the front cover, a 
computer printout picture of our 
favorite Vulcan. 

I was left with one sort of puzzling 
feeling. David Ahl obviously has a 
great concern and care about educa¬ 
tional reform and for loosening some 
of the restrictive, stultifying aspects of 
the education establishment (Ed Bus) 
... but there seems to be little con¬ 
sideration of anything but formal 
education here. Isn’t it conceivable 
that the Sesame Street idea coupled 
with the home computer may move 
the task of preparing our children to 
live in our society out of the formal 
classroom and back into the home? 
Just a thought. 

In Summary 

Does The Best of Creative Com¬ 
puting, Volume / have anything to 
offer the computer hobbyist? If 
you’re looking for hardware hints, no. 
If you're looking for software tips, 
maybe. If you’re looking for games, 
yes. And if you're in search of the Big 
Picture, absolutely. 

PACE: Logic Designers’ Guide to 

Programmed Equivalents to TTL 
Functions; 

National Semiconductor 

Corporation, 2900 Semiconductor 
Drive, Santa Clara, California, 
95051; Order Number IPC-16A/927; 
Publication Number 4200127X; $5.00 

Some years ago, when the minicom¬ 
puter first appeared, the conventional 
wisdom stated that these devices 
would generally replace special pur¬ 
pose logic assemblies and that logic 
designers would metamorphose into 
programmers. However, consider¬ 
ations of speed and cost intruded and 
the impact of the minicomputer on 
special purpose one-of-a-kind logic 
was never as great as expected. Now 
the same sort of impact on special 
purpose logic design is being attri¬ 
buted to the microprocessor, a much 
less costly device. 

This book is National Semicon¬ 
ductor’s attempt to promote the 
microprocessor, in particular their 
PACE unit, as the logical successor to 
special logic arrays and to aid the logic 
designer in the necessary transition to 
part-time programmer. The title of the 
book is descriptive of both the con¬ 
tents and the intended readership. 

The book begins with a brief intro¬ 


duction to the basic concepts of the 
digital computer in general and of the 
microprocessor in particular and to 
the general concepts of software. The 
hardware-oriented sections are very 
sketchy and obviously assume that the 
reader is fairly knowledgeable and 
really needs little introduction to the 
subject. The software section, how¬ 
ever, assumes that the reader has little 
or no familiarity with the various 
levels of programming and does an 
excellent job of introducing the 
concepts of assemblers, translators, 
loaders, and the programming process. 
This is all done in an informal tutorial 
style that is easy to read and to 
understand. 

The introductory material is fol¬ 
lowed by two sections on the particu¬ 
lars of the PACE unit. One lengthy 
section describes the instruction set 
and a shorter section provides infor¬ 
mation on input/output. The instruc¬ 
tion set material is typical in content 
and format of any computer reference 
manual. This can be scanned once and 
then used as reference data when 
required. The input/output section is 
brief but covers the material ade¬ 
quately and does a good job of 
describing the interrupt system if you 
have some hardware background. 

Special purpose logic of the type 
treated in this book rarely exists by 
itself. It may be driving the light bulbs 
of a simple visual indicator or con¬ 
trolling a complex piece of scientific 
apparatus but special logic is inevit¬ 
ably interfaced to something. This 
book is therefore of little interest to 
the user whose microprocessor is 
dedicated to pure computation or to 
computer games and which ties only 
to one or two standard peripherals. 

The book is aimed at the working 
hardware designer with little or no 
software background but with a sound 
basis in logic, a fact explicitly stated 
in the title. For that somewhat narrow 
readership this is an excellent book. 
For those without the grounding in 
logic devices it is likely to be rather 
difficult reading.» 

A. H. McDonough 

Microcomputer Design by Donald P. 

Martin; edited by Kerry S. Berland; 

Martin Research, 3336 Commercial 
Avenue, Northbrook IL 60062; 

390 pages; $25.00. 

This is an advanced book with a 
wealth of detail for the hardware 
designer who intends to start with 
8008 or 8080 chips and fabricate a 
complete microcomputer. It should 
also be of interest to the owner/user 
of a microcomputer with the ambition 
and the technical ability to undertake 
major additions or modifications to 
the system. However, the technical 
content and the very detailed design 
data do concentrate far too heavily on 
the 8008. While the 8008 is not 
actually obsolete it is no longer state 
of the art and is unlikely to be the 
device selected for new applications. 

The book includes as an appendix a 
set of 8008 and 8080 data sheets. In 
the preface the author suggests that 

continued on page 24 
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Is the Z80 
the Wave of 
the Present? 


Motorola 6800 
(clock cycle ° 1 usee) 
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single byte instruction <2 microseconds). 
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Step right up, folksl See the mighty Z80 do battle with the 
8080 and the 68001 Pat Godding has presented us with some 
interesting facts and some comparisons of these three popular 
microprocessors. Now, I'd like to see someone run some tests 
with the three (both hardware and software evaluations) using 
game or small business routines (or whatever) and see which is 
really fastest, most efficient, most easily programmed, etc. — 
John. 
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T he general purpose 
microcomputer has 
found an extremely large 
market (both industrial and 
hobbyist). This is not surpris¬ 
ing since there are a vast 
number of applications where 
a minicomputer is both an 
overkill and much too expen¬ 
sive. 

It is the size of this market 
that caused the other main 
manufacturers of integrated 
circuits to follow Intel's lead. 
Since the Intel 8080 pro¬ 
cessor chip was the first to be 
used in a general-purpose 
computer system, some of 
the manufacturers chose to 
produce pin-for-pin replicas. 
A different approach was 
taken by Motorola. This was 
to simplify the external hard¬ 


ware required to support the 
processor. This latter 
approach became the 6800. 

Although the 6800 is 
easier to interface and has a 
more flexible instruction set, 
it's clock speed is about one 
half of the 8080's clock- 
speed, and it contains no 
separate input/output struc¬ 
ture (I/O devices must use 
memory locations for com¬ 
munication). 

Although many new pro¬ 
cessors have become avail¬ 
able, some faster, some less 
expensive, and some requiring 
less interface hardware, none 
possessed any earth-shattering 
breakthroughs — until the 
Zilog Z80 was announced 
several months ago. 


Note: A minimum of 4 cycles (each 500 usee) are required to execute a 
single byte instruction (2 microseconds). 


Zilog Z80 

(clock cycle = 400 nsec) 
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Note : A minimum of 4 cycles are required to execute a single byte 
instruction (1.6microseconds). 


Fig. 1. Timing diagrams for 1 machine cycle (READ). 


20 












00 

07 


01 ‘ 
SYNC — 


N?_ 

8-BIT 

LATCH 

a STATUS 

/ 


" 1 •information 

=1 

1 Y strobe 

1_ r 


Fig. 2. Status information latching circuit 


The Z80 incorporates the 
best features of both the 
8080 and the 6800, and adds 
some very powerful features 
of Zilog's own creation. 

External Hardware 

The 8080 requires two 
clock phases and three volt¬ 
age supplies (+5, -5, and +12 
V). The 6800 simplified this 
by going to a single +5 V 
supply but at the expense of 
reducing the maximum clock 
frequency by one half. The 
basic 8080 clock frequency 
maximum is two megahertz; 
for the 6800 it's one mega¬ 
hertz. 

The Z80 uses one clock 
phase and a single +5 V sup¬ 
ply, and the maximum clock 
frequency for the basic Z80 is 
2.5 MHz*! This is a phenom¬ 
enal speed for MOS LSI 
technology (Metal Oxide 
Substrate, Large Scale Inte¬ 
gration) since the speed of a 
MOS LSI device generally 
suffers when the voltage is 
reduced, as seen above in the 
6800 processor. 

Fig. 1 shows timing dia¬ 
grams for the 8080,6800 and 
Z80. The 8080 "talks" to the 
external world by multi¬ 
plexing its data lines. The 
term multiplex in this de¬ 
scription simply means that 
the data lines are used for 
more than one purpose. The 
different purposes never 
conflict because they occur at 
different times during any 
given cycle. At the beginning 
of each cycle, the 8080 sends 
out a signal called SYNC. 
When this signal is coinciden¬ 
tal with the phase one clock 
(01), the data lines contain 
status information. These 
status signals tell the external 
hardware what type of cycle 
is about to be executed, e.g.: 

* Note / All three processors are 
available in faster versions. 


read from memory (MEMR), 
read I/O (INP), write to I/O 
(OUT), etc. These signals are 
used by the memory blocks 
and device interfaces so that 
only one memory location or 
I/O device is selected during 
any given cycle. To maintain 
the status information 
throughout the cycle it must 
be latched (stored) as shown 
in Fig. 2. Thus, each time a 
SYNC pulse is generated, the 
latch will be updated to con¬ 
tain the new status informa¬ 
tion. The primary advantages 
of this multiplex scheme is 
that it effectively increases 
the number of signal lines 
available on the 40-pin 1C 
package. The number of pins 
available for control signals is 
a problem when there are 
already 29 pins used for 
address, data, supply, and 
clock lines. By effectively 
increasing the number of 
signals available, the 8080 is 
able to use an I/O structure 
separate from memory. The 
8080 can access 64K words 
of memory (IK = 1,024) and 
256 I/O devices. The 6800 is 
limited to accessing memory 
only (also 64K words) and 
uses memory locations for 
I/O device interfacing. 

On the other hand, the 
6800 is simpler to interface 
since it does not multiplex 
any lines; if a read cycle is 
being executed, the R/W 
(read/write) signal is in its 
high state coincidentally with 
the correct address. 

The Z80 uses the same 
simple type of control as the 
6800 but maintains the 8080 
type of I/O structure. By 
gaining the four pins used on 
the 8080 for SYNC, one 
clock pulse and two voltage 
supplies, the Z80 eliminates 
the need for multiplexing. 
This makes hardware imple¬ 
mentation easier and, even 
more important, it allows 


memory to be accessed earlier 
in a cycle, so that slower 
memory chips can be used 
(slower memory is less expen¬ 
sive). Two signals, MREQ 
(memory request) and IORQ 
(I/O request) are used to 
select memory or I/O devices, 
respectively. Two other 
signals, RD (read) and WR 
(write) define whether the 
memory or I/O will be read 
or written, respectively. This 
structure simplifies system 
design. 

Zilog has also included a 
very important feature not 
found on other micropro¬ 
cessors. Dynamic Random 
Access Memories are rela¬ 
tively inexpensive, low in 
power, and fast, but they 
require constant clocking, 
called refresh, to maintain the 
internal charges that repre¬ 
sent data. This must be 
accomplished without the 
processor "knowing about 
it." The ideal time for refresh 
to occur is when the pro¬ 
cessor is working internally. 
Each time a new instruction 
is fetched from memory, the 
instruction is decoded in the 
processor in the last part of 
this fetch cycle. This period is 
called Machine Cycle 1 (or 
Ml), clock cycle 4 (or T4). 
Thus, a controller for dynam¬ 
ic memory in an 8080 system 
must decode this Ml, T4 
period to provide a refresh 
signal. The controller must 
also keep track of the refresh 
address and present it 
coincidentally with the re¬ 
fresh signal. 

The Z80 has its own inter¬ 
nal dynamic memory con¬ 
troller. During each Ml, T4 
period, the Z80 provides a 
refresh signal (called RFSH) 
and also places the next 
sequential refresh address on 
the lower 7 address lines (4K 
dynamic RAMS require the 
lower 6 address lines for 
refresh and 16K RAMS 
require the lower 7 address 
lines). Thus, the memory 
boards can contain less con¬ 
trol logic and more memory. 

Internal Hardware 

The 8080 contains 6 user 
accessible registers which are 


each 16 bits wide. (Refer to 
Fig. 3.) Three of these regis¬ 
ters are general purpose and 
can also be used as six indi¬ 
vidual registers that are 8 bits 
wide. The remaining three 
registers are the Program 
Counter (PC), the Stack 
Pointer (SP), and the Accu¬ 
mulator/Flag. Most arithme- 

MOTOROLA 6800 



INTEL 8080 



ZILOG Z80 



Fig. 3. Internal block dia¬ 
grams illustrating user acces¬ 
sible registers. (Number in 
parentheses indicates the 
number of bits in a register.) 
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tic and logic functions use the 
8-bit Accumulator and the 
status of the results are stored 
in the 5-bit Flag register. The 
6800 is similar, except that it 
contains an index register for 
added software flexibility and 
has no general-purpose regis¬ 
ters. Also, the 6800 has 2 
accumulators. 

To maintain software 
compatibility, the Z80 
includes the 8080 register 
bank as a subset In addition, 
the Z80 has seven more 
16-bit registers! Three of 
these are general purpose and 
identical to the other general 
purpose registers. A single 
instruction allows the pro¬ 
grammer to access either 
register bank. The remaining 
four registers are a second 
Accu mu lator/Flag register, 
two index registers (IX and 
IY), and an Interrupt/Refresh 
(IR) register. 

The 16-bit index registers 
normally contain base ad¬ 
dresses used for building 
tables of data. The 8-bit 
Interrupt register holds the 
upper address for mode 3 
interrupts (see Interrupt). 
The 8-bit Refresh register is 
the address counter used for 
dynamic memory refresh. 
Needless to say, with these 
additional accessible registers 
and an increase in the internal 
“housekeeping" logic, the 
Z80 has a much greater 
instruction set 

Instruction Sets 

The machine language 
instruction set is physical 
hardware. A program, or 
group of machine instruc¬ 
tions, is software. When a 
machine instruction is exe¬ 
cuted, the states (logic zeros 
or logic ones) of the 8 bits 
contained within the instruc¬ 
tion are decoded by internal 
logic to define what function 
the processor must perform. 
Generally, when more 
instructions are included in 
the machine instruction set, it 
takes fewer of these instruc¬ 
tions to perform a given task. 
This decreases the amount of 
memory needed for a given 
program and the program will 
normally execute faster. 


The 8080 has 78 machine 
instruction types. An exam¬ 
ple of a machine instruction 
type is REGISTER INCRE¬ 
MENT. An operation code 
(op code) is the actual bit 
pattern that represents a 
machine instruction and each 
one is a unique group of 8 
bits. Since the 8080 has six 
8-bit registers and an accumu¬ 
lator, all of which can be 
incremented, there are 7 
distinct op codes (or bit pat¬ 
terns) representing this one 
instruction type. The 78 
instruction types of the 8080 
constitute 244 op codes. The 
6800 has 72 instruction types 
with 197 op codes. 

The Z80 contains 158 
instruction types, including 
all of the 78 instructions of 
the 8080. The total number 
of op codes is 696! Two of 
these additional instructions 
greatly increase the software 
speed of the processor. The 
first type is the block instruc¬ 
tion. This allows blocks of 
data contained in one section 
of memory to be moved to 
any other section by exe¬ 
cuting a single instruction. 
The block size can be any¬ 
where from 0 to 64K. Blocks 
of data up to 256 words can 
be transferred between 
memory and I/O devices. In 
addition, a block of memory 
can be searched for a particu¬ 
lar bit pattern defined by the 
accumulator. The search 
continues until a match is 
found or the specified search 
length has been reached. 

The second instruction 
type is bit manipulation. This 
set of instructions can set, 
reset, or test any bit in a 
register or memory location. 
The normal instructions 
required by the 8080 are used 
to load the accumulator and 
perform a logical AND with 
the specified bit A large pro¬ 
gram may require this type of 
function many times. 

Addressing Modes 

Data is stored in internal 
registers, memory locations, 
and/or I/O devices. The ma¬ 
chine instruction must obtain 
the address of the data in 
order to access it. Each ad¬ 


dress mode obtains the ad¬ 
dress in a different manner.* 
The 8080 has 4 Addressing 
Modes: 

a) Extended 

The op code is followed 
by 2 bytes that specify the 
address of the data. (Exp: 
Jump to the address specified 
by bytes 1 and 2.) 

b) Register 

The op code specifies a 
register or register pair that 
contains the data. (Exp: Load 
the contents of the B register 
into the Accumulator.) 

c) Register Indirect 

The op code specifies a 
register pair that contains the 
memory address of the data. 
(Exp: Load the Accumulator 
with the contents of the 
memory location addressed 
by registers B and C.) 

d) Immediate 

The op code is followed 
by 1 or 2 bytes of data. (Exp: 
Load the Accumulator with 
the data immediately follow¬ 
ing the op code.) 

The 6800 has 7 Addressing 
Modes: 

a) Extended 

b) Immediate 

c) Accumulator 

Specifies 1 of the 2 accu¬ 
mulators (e.g., increment the 
B accumulator.) 

d) Direct 

Same as extended, except 
only 1 byte specifies the 
address (limited to addressing 
only the lowest 256 words of 
memory). 

e) Indexed 

The op code is followed 
by 1 byte that is adder, to the 
index register. This sum 
becomes the address. A tem¬ 
porary register is used for the 
addition so that the index 
register is unchanged. (Exp: 
Load the Accumulator with 
the contents of the memory 
location specified by a 
number (0-255) plus the 
index register. 

* Note ; The 8080 and 6800 u$e 1 
byte (8 bits) to contain each op 
code. The op code may require 
additional bytes for execution. 
These are either 1 or 2 bytes 
immediately following the op 
code. The Z80 uses the same 
instruction format, but either \ or 
2 bytes may be used to contain 
the op code. 


f) Implied 

The op code implies the 
location. (Exp: Add the B 
register and the Accumulator. 
It is implied that the result 
will be stored back into the 
Accumulator.) 

g) Relative 

The byte following the op 
code is added to the program 
counter (PC). This new ad¬ 
dress is then jumped to if 
tested conditions are met 
(Exp: If Carry is set, jump to 
PC+ 64.) 

The Z80 has 8 Addressing 
Modes: 

a) Extended 

b) Register 

c) Register Indirect 

d) Immediate 

(Note: The above 4 modes 
maintain software compati¬ 
bility with the 8080.) 

e) Indexed 

f) Implied 

g) Relative 

h) Bit 

There is a large group of 
instructions that can set, reset 
or test an individual bit 
within a memory location or 
register. (Exp: Reset bit 2 in 
the memory location speci¬ 
fied by registers H and L.) 

In addition to the above 
modes, instructions may use 
two or more combinations of 
these modes for execution. 

Interrupt Structure 

Multilevel interrupts in the 
8080 are provided by the 
RST (Restart) instruction. 
Three bits of this instruction 
define which of eight possible 
locations will be jumped to 
when the processor receives 
an interrupt signal. These 
three bits are provided by an 
interrupt control module 
which sets priorities for up to 
eight incoming I/O interrupt 
lines and allows only the 
highest priority to interrupt 
the 8080. 

The 6800 has two modes 
of interrupt. The first mode 
requires that the interrupt 
enable instruction has been 
executed. Then an incoming 
interrupt causes a jump to a 
location defined by the con¬ 
tents of two bytes of memory 
(FFF8 and FFF9). The other 
mode is similar except that it 
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uses address locations FFFC 
and FFFD and does not 
require the enable interrupt 
instruction to be executed 
The Z80 has three modes 
of interrupt. The first mode is 
identical to the 8080. The 
second mode immediately 
jumps to location 38 when an 
interrupt is received (and the 
interrupt enable instruction 
has been executed). The third 
mode is by far the most 
flexible. When an interrupt is 
received, the processor forms 
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the "novlcc f * begin by reading these 
data sheets and then reading chapters 
2 and 3 which describe, respectively, 
the 8008 CPU and the 8080 CPU. An 
even better suggestion for the novice 
is to read some other text and gain 
some hands on experience before 
approaching this book. Microcom¬ 
puter Design is surely no book for the 
beginner. The twenty-five dollar cost 
alone would emure that. 

To add to the novice's problem the 
chapters on the 8008 and 8080 CPUs 
are by no means the best chapters in 
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hardware — but even more important 
they have some good business pro¬ 
grams that they have developed and 
are marketing. It's good to see com¬ 
puter stores working to sell microcom¬ 
puters for business uses. 

BACK HOME 

It was the encouragement given by 
all Ejf the manufacturers and dealers 
we visited during lliis 10,000 mile 
pilgrimage that resulted in Kilobaud 
getting started. We discovered that the 
magazines in the hobby computing 
field were riot doing what a lot of the 
industry fell should be done — and 
there seemed to be agreement that my 
concept of a magazine which begin¬ 
ners could read was badly needed. 

Yes, t realize that getting experts in 
this field to write so all of us can 
understand what they are trying to 
explain is going to be very difficult 
and I know wc f re iusl not going to 
make it all the time, but well he in 
there pitching. 


a 16-bit address, in which the 
contents of the interrupt 
register constitute the upper 
8 bits [this register is loaded 
via software) and the I/O 
device supplies the lower 8 
bits. This 16-bit address 
represents the memory loca¬ 
tion that contains the actual 
address of the interrupt 
service routine for the device. 
Thus, the device service rou¬ 
tines can be located sepa¬ 
rately from each other any¬ 
where in memory, and the 


addresses for these routines 
can all be contained together 
in a table whose starting 
address can be at any location 
in memory. This indirect 
addressing scheme is called 
vectoring. 

Conclusion 

The Zilog Z80 is much 
more powerful than either 
the 8080 or the 6800. There 
are certainly a large number 
of applications that need the 
power of a Z80. However, in 


a generahpurpose, stand alone 
microcomputer system, the 
8080 and 6800 type pro¬ 
cessors have proven to be 
very efficient. Perhaps the 
brief comparisons shown here 
will impress some personal 
computer users, but whether 
those users will be motivated 
to upgrade their systems, 
remains to be seen. And with 
the 8080 bus compatible Z80 
CPU boards available (in¬ 
cluding one from MITS), we 
should see very soon. ■ 


the hook. The novice will spend more 
time referring to the data sheets and 
to other chapters, digging out data, 
dclinitions, and concepts, than he will 
reading the chapter at hand. The book 
is simply not organized as a tutorial 
text and attempting to use it as one 
will most likely persuade the novice to 
take up some other line of work. 

However* starting with chapter 5 on 
Main 1 iming, the book is an excellent 
aid |t> the experienced designer who is 
now working with 80G8/SGS0 micro¬ 
processor or microcomputer systems. 
The book covers a variety of topics 
(2b chapters and 390 pages) including 
bus structures* inpul/outpul, ROMs, 
RAMs, DMA and interrupts. Several 
chapters deal with the connection to 
the outside world, to peripherals, to 
analog devices and tu special circuits 


which extend and expand the func¬ 
tions of the 8008. The last two 
chapters give sample designs for 
microcomputers, ranging from the 
smallest system worthy of the name 
to a relatively sophisticated unit using 
19 chips. 

Throughout chapters 5 through 26 
the emphasis is on the specific and the 
practical. The circuits used to imple¬ 
ment the various functions are dearly 
diagrammed with the appropriate 1C 
chip number, and the operation and 
timing ate discussed In detail. Some 
consideration U also given to the 
much neglected areas of cost and ease 
of manufacture, not a lot of consider 
ation but at least some. 

One small complaint is the rcla 
lively Jit tie attention devoted to soft 
'ware. One short chapter presents a 


few useful concepts, all of which are 
related Somehow to hardware prob¬ 
lems. It may be argued that this is, 
after all, a hardware design book. 
However, that simply perpetuates the 
isolation of hardware design from 
consideration of the end use. There is 
already too much of that. 

That philosophical objection aside, 
Microcomputer Design should be a 
valuable book for an experienced 
designer working with 8008 and 8080 
based systems. The emphasis is too 
much on the 8008 rather than the 
8080 and hopefully the author will 
reverse that emphasis in future edi¬ 
tions. Despite this, the book does 
cover a broad range of topics in 
admirable detail. For the beginner* 
however, a simpler book would be 
best. ■ 

A. H. McDonough 


The first announcement of the new 
magazine to the public at large was at 
our booth at I he PC-76 in Atlantic 
City, Apparently a lot of people 
thought my idea was a good one for 
we were mobbed and sold a lot of 
subscriptions. 

My visit lo the hobby computer 
industry was encouraging — some 
firms are doing very well, others are 
hurting. In general most of those who 
arc not being rushed for deliveries 
have a credibility gap which has been 
generated cither by vague advertising, 
poor deliveries ... or both. There is 
no question that the field is not 
experiencing the growth which was 
expected, but this is not all that 
surprising for litllc has been done to 



lhe window " grabber" is on Altair 
controlled model train system. It sure 
brings them in. 


bring news of the new hobby to the 
general public. Outside of the large 
number of articles in 7J Magazine and 
a litllc bit in Radio Electronics and in 
Papular Electronics,, there has been 
very little PR. 1 he 75 or so recent 
articles in 13 on hobby computers has 
brought in tens of thousands of hams, 
but other than that there seems to 
have been little growth. This is some¬ 
thing tu think about. ■ 



The Systemscenter has the intelligent 
Systems unit working, connected to 
an Altair 680 and a National Multi¬ 
plex cassette system, fust about alt of 
the programs available for this unit 
have been developed by the fellows 
here . 



The Systemscenter is aimed at the 
hobbyist , the professional , and the 
homeowner. A Cromemco Banter 
with Life playing on it is on display 
(in color) near the window and it, too, 
keeps people watching particularly 
at night , 
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altair 8800 b 


The ALTAIR BBOOb computer is o general purpose 
byte-oriented machine (8-bit wordK It uses a common 
1O0-pin bus structure that allows for expansion with 
either standard or custom pfug-in modules. It 
supports up to 64K of directly addressable memory 
and can address 256 separate input and output 
devices. The ALTAIR 8800b computer has 78 basic 
machine language instructions and is comprised of a 
power supply board, a D/C interface board, a central 
processing unit (CPU) board, and a display/control 
board- 

NEW DESIGN FEATURES 

Severn! new design features have been incorporated into the 
electronic and mechanical areas of the ALTAIR BBOOb 
computer Some of the new design features include additional 
front panel capabilit es, redesigned power supply, and various 
electronic and mechanical design advancements 



Mechanical Design Advancements 

The mechanical design advancements on the ALTAIR S900b 
are incorporated for ease of assembly and maintenance 


New Front Panel Switches 

Five new front panes switch positions hove been added to the 
ALTAIR BBOOb computer to expand the front panel capability 

1 SLOW Permits execution of a program at a rate of 
approximately 1 machine cycles per second or slower 

2 DISPLAY ACCUMULATOR Displays the contents of 
the CPU accumulator register on the ALTAIR 8900b 
front panel 

3 LOAD ACCUMULATOR : Loads the information 
present on the lower eight front panel address switches 
into the CPU accumulator register 

A INPUT ACCUMULATOR Inputs the information 

present at an Input/Output device mto the CPU accumulator 
register The Inpul/Output device is selected on the upper 
eight front panel address switches 
5 OUTPUT ACCUMULATOR Outputs the contents of 
the CPU accumulator register to a selected input/output 
device The in put/out put device is selected on the upper 
eight front panel address switches 

New Power Supply 

The new power supply in the ALTAIR 9000b contains an 3 
volt h 18 ampere tapped secondary supply which permits the 
addition o# up to 16 printed circuit cards, and pre-regulated 
positive and negative 18 volt H 2 ampere supplies A multiple 
tapped primary transformer provides for 110/2 20 volt 
operation and a 50/60 Hi operatron 

Electronic Design Advancements 

The electronic design advancements on the ALTAIR 8800b are 
in the CPU and front panel circuit boards 

1 CPU The new CPU circuit board uses thn Intel 8 2 24 clock 
generator integrated circuit (1C) The 9 2 24 1C provides a 
specified clock frequency to the ALTAIR S80Qh using an 
external crystal and dividing the crystal frequency down to 
2MHz Therefore, both the clock pulse widths and phasing 
(as well as frequency) are crystal controlled 

2 Front Panel AH front panel data linos are connected to the 
D/C Interface Board which buffers thorn from the rest of the 
ALTAIR BBOOb. The front pane* circuits also use a 
programmable read only memory (PROM) which contains 
programs for the following eight functions 
EXAMINE/EXAMINE NEXT 

ACCUMULATOR DlSPLAY/ACCUMULATOR LOAD 
DEPOSIT/DEPOSIT NEXT 

INPUT ACCUMULATOR/OUTPUT ACCUMULATOR 
3. The front panel circuits also have a wiring option which 
allows ihe CPU to perform b complete instruction cycle or a 
single machine cycle during the single step or slow operation 


1 Two ribbon cable assemblies connect the D/G Interface 
board to the Display/Control Board Thus, the need for 
complicated bus wiring has boon eliminated 

2 A single piece 18-slot motherboard has repraced the four 
slot expander cards in the ALTAIR 8800 The 18-slot 
motherboard contains lOQ solder lands which comprise 
the 1D0 pin bus 

3 A now multi-color and redesigned dress panel is used in the 
ALTAIR 8800b The front surface of the dress panel has a 
protective sheet of mylar to insure that the graphics are 
not rubbed or scratched Off 

Compatibility 

All of the current SB0G software and all of the current 8800 
plug-rn circuit boards are compatible with the Altair BBOOb 
(with the exception of the 8800a CPU board). 


ALTAIR 0800b 

Specifications 

Number of Boards 

Up to 19 

Microprocessor 

Model 

80SOA 

Technology 

NMOS 

Data Word Size, Brts 

8 

Instruction Word Sue. Bits 

8 

Clock Frequency 

2M Hz 

Add Time, Register to Register 

Microsec Per Data Word 

2 

Number of Instructions 

78 

Input/Output Control 

I/O Word Size, Bug 

8 

Number of I/O Channels 

286 

Direct Memory Access 

Optional 

Interrupt Capability 

Std 

Vectored Interrupt 

( 8 priority levels J 

Optional 

Software 

Residoni Assembler 

Yes 

Higher-level Language 

SASIC 

Monitor or Executive 

SyS Mon , text edit 

Complete Software Library 

Separately Priced 

Yes 

Price 

S840.00 kit w/2 edge connectors 

$1100.00 assembled w/G o 

df|o connectors 



























16K Static Memory 
Board (88-16MCS) 


Synchronous 4K Memory 
Board (88-S4K) 
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The 88-16MCS design is based 
upon a 4,096 x 1 bit static 
random access integrated circuit. 
These RAMs offer the advantage 
of low power consumption and 
extremely fast access time, and 
also eliminate the need for 
additional refresh logic common 
to dynamic memories. 

Hardware 

Dimensions: 10 Ph x 5" 

Altair SJots: One 

Power; + 5V (400 mA, Max.), + 12V 
(200 rnA, max.), - 5V (TOO mA). 

Epoxy solder masks cover areas not 
to be soldered. 

Sockets are provided for all RAM ICs, 

A DIP Switch is used for board address 
selection t 


Capabilities 

Provides 16,384 8-bit words of Random 
Access Memory on one card. 

Access Time: 215 ns. 

Cycle Time: 390 ns. 


Operation 

There are no wait states (due to fast 
access time). 

Since only four 88-1 6MCS boards are 
required for the maximum amount of 
memory directly addressable by the 
computer, only the upper two address 
bits are required to select a particular 
board. The upper four address bits select 
a single 4K block on a particular 16K 
card. The remaining twelve address bits 
are buffered and inverted to select one 
location within a block. 


Price: $765 kit 

$945 assembled 
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The 88-S4K Board is totally 
synchronous—this means that 
the board relies solely on the CPU 
for timing signals (no single 
shots). The S4K provides 4,096 
bytes of Random Access Memory- 
Each board contains memory 
protect circuitry, and address 
selection circuitry for any one of 
16 starting address locations in 
increments of 4K. 


Hardware 

Dimensions: TO" x 5* f 
Altair Slots: One 
Power (worst case): 

*+■ 5V at 450 milliamps 

+ 12V at 290 milliamps 

+ 12V at 10 milliamps [unselected) 

Epoxy solder mask 
Sockets provided for RAMs. 

No hardwire jumpers. 

A DIP switch is used for board select. 

Capabilities 

Runs at maximum speed (no wait states). 

The entire 4,096 bytes of memory can 
b© protected by switching to PROTECT. 
Access Time: 200-300 ns. 


Price: $155 kit 

$255 assembled 
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2-Port Serial I/O 
Board ^ (88-2SIO) 



The 88-2810 Board design is 

based upon an Asynchronous Communications 
Interface Adaptor (ACIA). The ACIA contains 
both the control register and the status register, 
so that most options are software selectable. 
Hardware 

Level Selection; Wire jumpers. 

Baud Rate Generator: Crystal-controlled 
CMOS divider/low power multiplexer 
Device Connection : 12 conductor cable; 

10-pin removable connector on board 
25-pin connector on back panel 
Altair slots: One 
Power: 

+ 5V at 520 mitliamps 
+ 15V at 70 milfiamps 
- 15V at 70 milliamps 

Capabilities 

The 88-2SIO board has two serial input/output 
ports. Each port provides 5 control lines, allowing 
maximum utilization of sophisticated terminals. 

The five control lines are; 

Transmit Data, Receive Data, Data Carrier 
Detect, Clear To Send, Request To Send 

All lines are user selectable for ±9v levels (R3-232), TTL 
levels {0-5V), or 20 milliamp current loop (Teletype). 

Full S-bit Status Register provides: 

Received Data Available Framing Error 
Transmitter Buffer Empty Received Data Overflow 
Carrier Detect Parity Error 

Clear to Send Interrupt Request 

The 8-bit status register allows for greater 
control and handshaking ability. 

Provides an on-board, crystal-controlled clock 
for any of 8 baud rates (with a single jumper): 

HO, 150, 300, 1200, 1800, 2400,4800, 9600 
A programmable counter can provide other baud rates: 

37.5 75 600 

2SIO, with 2 ports, can interface 2 serial 
I/O devices, each running at a different baud rate 
and each using a different electrical interconnect. 

Thus, 2 ports can be operating entirely independently of 
each other (such as an RS-232 CRT terminal running at 
9600 baud and a 20 milliamp Teletype running at HO baud). 
Interface levels; TTL, RS-232, TTY. 

Bit Configuration: Software selectable 

for 7 or 8 bits, 1 or 2 stop bits, odd or even parity. 

Price: $148 kit extra port: 538.00 

$180 assembled extra port: $50.00 


4-Port Parallel 1/0 
Board (88-4PIO) 



The 88-4PIO board design is 
based upon a peripheral interface 
integrated circuit. The chip 
contains all control and data 
registers, thus most 88-4PIO 
options are software selectable. 
These options include data 
direction (each data line can act 
as input or output) and interrupt/ 
control structure modification. 

The 88-4PIO board can be 
expanded to four ports (four 
6820 ICs>, making it one of the 
most powerful and versatile 
interface boards available. 

Hardware 

The 4PIO board connects to the back 
panel of the computer with a removable 
flat cable. The cable has a 24-pin 
removable plug on the board, and a 25- 
pin connector on the back panel, 

Altair slots: One. 

Power: + 5 volts at 500 milliamps with 
4 ports. 

Capabilities 

The 4PIO board is capable of handling up 
to 4 ports on one plug-in card. Each port 
contains 16 data lines. Each line can be 
initialized as input or output to interface 
a terminal {8 lines in, S lines out). 

Each port on the 4PIO board can handle 
2 inputs (such as a paper tape reader and 
keyboard) or two output devices (such as 
a paper tape punch and printer) or any 
combination of custom applications. 

All data lines are fully TTL compatible. 
Eight of the 16 lines are capable of 
directly driving the base of a transistor 
switch (1,5V at 1 mah 
A 4PIO with 4 ports has 64 data lines 
{each group of 8 is Individually selectable) 
and consumes 500 ma at BV — typicol. 

Bit Configuration : Each data line can be 
software selected to act as an input or 
output- 

Pric©: $105 kit 

$130 assembled 

for each extra port (up to 3) add: 

$38 kit $55 assembled 




altair 

Floppy 


(88-DCDD) 


The 88-DCDD is comprised of 
the Disk Controller and one 
Disk Drive with an 
interconnect cable. The Disk 
Controller consists of 2 PC 
boards (over 60 ICs) that fit in 
the Altair chassis. Each 
controller can address up to 16 
disk drives. The Disk Drive 
unit consists of a PERTEC 
FD-40O, a power supply PC 
board, and a Buffer/Address/ 
Line Driver PC board. The Disk 
Controller converts the serial 
data to and from 8-bit parallel 
words (one word every 32 
microseconds). The Disk 
Controller also controls all 
mechanical functions of the 
disk as well as presenting disk 
status to the computer. 


Altair Floppy Disk 
Drive Unit* 


Hardware Specifications 
Access Time: 

Track to track : 10 ms* 

Head load and settle time : 45 ms. 
Average time to read or write: 

400 ms. 

Worst case: 1135 ms. 

Rotational speed: 360 RPM (166.7 
ms/rev) 

Tracks: 7 7 per disk 

Sectoring: Hard sectored, 32 sectors 
per track, 5,2 ms/sector (non IBM 
compatible) 

Data Transfer Rate : 250,000 bits/sec. 
(one 8-bit byte every 32 microseconds) 
Maximum number of drives per system , 16 


Software and System 
Features 

Altair Disk Extended BASIC is an 
enhanced version of Altair Extended 
BASIC with added capabilities for saving 
and loading programs, and for 
manipulating data files on disk. 

Altair Disk Extended Basic uses random 
and sequential files for storing 
information on disk. 

Utility software is included with Altair 
Disk Extended BASIC for copying 
diskettes, initializing blank diskettes, 
listing directories, etc. 

Disk bootstrap loader is available on 
paper tape, cassette tape, or PROM 
(used with 88-PMC PROM Memory 
Card). 

Altair Disk Extended BASIC requires a 
minimum of 20K of RAM memory for 
operation* 

PROM Disk Bootstrap loader allows 
loading of Altair Disk Extended BASIC in 
less than 10 seconds from the time 
power is turned on* 


Data storage capacity : 310,000 
bytes per disk 
Data bytes per sector: 128 
Data bytes per track: 4,096 
Disk Drive head life: over 10,000 
hours of diskette to head contact 
Disk Drive MTBF ♦ exceeds 4,000 
hours 

Disk Drive data reliability : not more 
than 1 in 10 5 soft (recoverable) errors, 
1 in lO 1 " hard (non-recoverabie)errors 
Power: 

Controller: 1,1 amps at + BV unregu¬ 
lated (from Altair bus) 

Disk Drive Unit: 110 watts 50/60 
Hz 117/220 VAC 

Diskette: Hard sectored, 32 sectors + 
index hole (Dysan #101, ITC ?FD 
32400} 

Disk Drive Unit Weight: 40 pounds 
Price: $1,480 kit 

$1,980 assembled 
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High Speed 

Paper Tape Reader 

(88-HSR) 


AUDIO CASSETTE 
RECORD INTERFACE 

(88-ACR) 


The S8-ACR allows reading and 
writing of data on audio 
cassettes, using frequency 
modulation. The 88-ACR may be 
used with any medium (or better) 
quality cassette tape, (Music 
quality recorders generally give 
better performance than smaller 
portable recorders.) 


The High Speed Paper Tape 
Reader design is based upon the 
REMEX 300-character-per- 
second opto-reader, The 88-HSR 
connects directly to t port of an 
88-4PIO parallel interface card or 
1 parallel port of an Altair 680b 
computer. 

Hardware 

Dimensions: high x 8)4“ wide x 11“ 

deep. 

Drive: DC stepping motor with sprocket 
drive. 

Power: 50 watts, running. 

READ Mechanism: Filament lamp to 
fiber optics to photo cells, The lamp is 
operated below voltage rating to greatly 
prolong life. 

Tape loading: Easy in-line front load. 

Software Features 

Start/stop on character. 

Low power standby mode. The standby 
mode reduces motor voltage during 
periods of inactivity, and allows tapes to 
bo read at the reduced speed of 30 cps. 

Specifications 

Reading Speed: 30 cps or 300 cps, 
software selectable, stops "on character’. 
Tapes: 

Light transmissivity: 57% or loss 
Thickness: ,0027-.0045 inch 
Type: standard B-track (1-inch) and 
most other standard 5, 6, or 7 track 
Data Output: TTL: 

a. Less than .4 volts at 16 ma (no hole); 
2.4-5 volts at .2 ma (hole), 

b. Plus-in compatible with 88-4P10 or 
Altair 680 parallel port. 


Features 

The 88-ACR may be used with machine 
language Read/Write programs or with 
ALTAIR BASIC commands, CSAVE and 
CLOAD, (8K and Extended versions), 

ALTAIR software is available on audio 
cassette tapes for loading into the 
ALTAIR through the 88-ACR. 

Uses any tape recorder with less than 
2% wow and flutter. The better the 
speed stability, the better the data 
integrity. 

Hardware 

General Description: 

Consists of 88-SIOB (Serial I/O Board) 
mated to a MODEM (Modulator/ 
Demodulator) board. 

Requires one slot in the ALTAIR bus. 
Connects to a tape recorder via 
miniature phone jacks (user supplies 
the interconnect cord). 

Specifications 

Modulation Frequencies: Logic 1-2400 
Hz, Logic 0-1850 Hz. 

Data Rate: 300 baud, 30 bytes/second. 
Bit Format : UART type (1 start bit, 8 data 
bits, 1 stop bit). 

Output Level: 100 MV p-p sawtooth, 
suitable for "’MIC" input of recorders. 
Output Impedance: 1.5K ohms. 

Input Level: 200 MV p-p to 10 V p-p. 
Input Impedance: TOOK ohms. 

Speed Tolerance: 2% without adjustment 
of PLL, 5% with adjustment of PLL. 
Connector Type: 3,5 mm in.) 
miniature phone jack. 

Price: 5138 kit 

$195 assembled 



110 Line Printer (88-LP) 
and Control Board 



The 88-LP produces 80 columns 
of 5 x 7 dot matrix characters at 
110 characters per second (70 
lines per minute), and will print 
up to three copies, plus the 
original. The universal input 
transformer allows world-wide 
use. The Line Printer is fully 
compatible with LP BASIC (8K or 
Extended). 

The Line Printer Controller 
(88-LPC Board) provides 
communication between the 
Altair and the Line Printer. The 
88-LPC can be jumpered for any 
one of 128 addresses and has full 
hardware interrupt capability. 

Hardware 

Dimensions: 18" wide x 8" high x 23" 
deep. 

Weight: 32 lbs. 

Requires 1 slot in the Altair bus. 

Alt control electronics are contained on a 
single 10" x 6" printed circuit board. 

Operation 

Print Method: Impact dot matrix prints 
bi-directionally, using a conventional 
typewriter ribbon. 

Print head moves uniformly in both 
directions and pauses only at the end of 
a line, minimizing vibration and wear. 
Opto-electronic sensing is used to 
accurately position each dot and to 
permit characters to be printed on the fly. 
Character Set: 64 character subset of 
ASCII. 

Character Spacing: IQ char./inch. 

Line Spacing: 6 lines/inch. 

Line Width: 80 characters. 

Paper Feed: Tractor feed, adjustable 
2”-97 

Paper Media: 2"-97 continuous fold. 

Line Voltage: 110, 117, 234 VAC ± 10% 
50-60' Hz (factory selectable). 

Price: $2200 kit 

$2375 assembled 


Vector Interrupt/ 
Real Time Clock 
(88-VI/RTC) 


The 88-VI gives the computer 
the capability to interrupt 
activity via the Restart (RSTJ 
instruction and to allow only 
the highest active priority of 
the 8 priority levels to 
interrupt the CPU* 

The ENABLE INTERRUPT instruction 
permits interruption. ENABLE INTERRUPT 
must also be activated after each 
interrupt is completed in order to 
reactivate the CPU's internal interrupt. 

The Interrupt Service Handler is the 
software device which supervises ail 
individual device service routines. 

The Real Time Clock provides the 
computer Ljser with the capability to 
interrupt the processor at one of four 
selectable rates. The RTC generates an 
interrupt after a precise interval of time, 
which enables software to time certain 
routines and even to generate the correct 
time, day, and year, upon request. 

The RTC source may be selected from 
either a derivative of the 2 megahertz clock 
or the line frequency The 2 megahertz 
clock should be used if a fast RTC is 
needed; it is selectable for time intervals 
down to 1QO microseconds. The line 
frequency (60 Hertz) should be used in 
systems that require accuracy over a long 
period of time. 

Specifications 

Clock Source Intervals: 

System Clock (2 MHz): 100 ns, 1 ms, 

10 ms, or 100 ms. 

Line Frequency (60Hz) Intervals: 16,67 
ms, 166,7 ms, 1.667 sec., or 16.67 sec. 
Accuracy : 2 MHz, .01%. 

Altair Slots: On© 

Power: 5 volts at 300 ma. 

Price: $138 kit 

S185 assembled 
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The ALTAIR 680b microcomputer is an excellent 
compromise between computer power and low cost 
structure, without sacrificing design reliability. The 
system is based on the 6800 microprocessing unit, 
which adapts nicely to a minimum design configuration. 
The ALTAIR 680b measures 11-1/16" wide x 11-1/16" 
deep x 4-11/16" high. The basic system is available in two 
configurations, depending on the intended application 

Almost all of the 6S0b circuitry is contained on a single large 
printed circuit board, including memory and a built-in 1/0 port 
The full front panel model contains all of the controls necessary 
to program and operate the computer and includes an additional 
printed circuit board, which provides all Of the logic circuitry 
necessary to reset* halt or start the processor. Atso located on 
this board are switches and associated LED Indicator lights for 
each of the sixteen address lines and eight data Tines The front 
panel circuit board mounts directly to the main printed circuit 
board v>3 a 100-contact edge connector The power switch is 
located on the back panel of the unit for safety purposes A 
“turn-key" front panel model, which eliminates all control except 
restarting the processor, is also available. 

At the heart of the 680b system is the 6800 Microprocessing 
Unit, which is largely responsible for the overall simplicity of the 
680b design The 6800 MPU contains three 16-bit registers 
and three 6-bil registers The program counter is a two byte 
register which keeps track of the current address of the program 
The stack pointer is also a two byte register which keeps track 
of the current address of the program end contains the next 
address m an external, variable length push-down/pop-up stock 
The index register is a two byte register used to store data or a 
memory address for indexed addressing operations. There are 
two single byte accumulators used for holding operands and 
results from the arithmetic logic unit (ALUI The 8-hn condition 
code register indicates the results of on ALU operation, in this 
register there are two unused hits, kept at a logic one The 
remaining six bits are used to indicate the status of the following 
carry, half carry, overflow, /Pro. negative, interrupt 

The 6000 has seven different addressing modes, with the 
particular mode being a function of both the type of instruction 
and the actual coding within the instruction The seven modes 
include the following- Accumulator Addressing—one byte instruc¬ 
tions. specifying either of the two accumulators: Immediate 
Addressing—two or three byte instructions, with the MPU 
addressing the location given in the 2nd or 2nd and 3rd bytes 
when the immediate instruction is fetched. Direct Addressing — 
two byte instructions which allow the user to directly address 
the lowest 256 bytes of memory in the machine* Extended 
Addressing - three byte instructions, the second two bytes 
referring to on absolute address in memory for the operation; 

Indexed Addressing — two byte instructions, ihe second byte 
being added lo the 16’bit index register to give the address of 
the operand. Implied Addressing—one byte instructions and 
the instruction itself gives the address; Relative Addressing — 
two byte instructions where the second byte is added to the 
lower 8 bits, allowing the user to address memory + 129 to 
-126 bytes from the location of tho present instruction 

NEW MEMORY FEATURES 

MIIS is pleased to announce the development of a 16K static 
memory card for the Altair 680b With an access time of 215 
nanoseconds and low power consumption of 5 watts, we feel 
that this is an excellent addition to the Altair 60OL-. 

The 660b cabinet has room for up to three 16 K static memory 
cards, thereby increasing the memory of the Altair 680b to 49 K 

SPECIAL FEATURES 

=*ROlV1 monitor. 

1702A PROM monitor chtp programmed so that you can 
immediately load and run paper tape object programs such os 
the text editor and assembler [see below) 





Asynchronous Communication 
Interface Adapter (AGIA>. 

Allows the machine to transmit and receive a character at a time 
rather than one bit. Minimizes software needed for 1/0 routines. 
Contains crystal clock for baud rate synchronization User- 
selectable for RS23 2. Baudot, TTY, 2Qma current loop Baud 
rates of 50. 75. IIO. 134 5. 150* 200. 300. 600. 1200* 

1800. 2400* 4800. and 9600 

Two Pass Resident Assembler and Text Editor 

A two pass resident assembler end text editor ere available 
for assembly language programming This software is 
compatible with Motorola's format for assembly language 
programs, text and object files 8K bytes of memory ore required 
to run this package. The assembler produces n full assembly 
listing on the second pass, including the hex codes for the 
location counter and the instruction mnemonics A symbol table 
listing is also produced The text editor has full capabilities for 
text editing, including lino insertion* printing, deletion and 
modification; as well as commands for changing one string of 
characters to another and for searching the text buffers for a 
particular character string 

Basic Interpreter 

A BASIC interpreter has boon developed which will be 
comparable to the 6800 8K BASIC mterpmter 


Altair 680b 

Specifications 

No of Boards 

Up to 3 additional 

Microprocessor 

Model 

6800 

Technology 

NMOS 

Data Word Size. Bits 

8 

Instruction Word Size* Bits 

0 

Clock Frequency, 

500 K Hz 

Add Time. Register to Register, 

Mtcrosec. Par Data Word 

4 

Number of instructions 

72 

Input/Output Control 

I/O Word Sire. Bits 

S 

Number of I/O channels 

2 56 Memory Address 

Loco lions Designated 

Interrupt Capability 

Std 

Type of Interrupt System 

Maskable {Interrupt Request) 
and Non-maskable Interrupt 

Software 

Resident Assembler and Editor 

Yes 

Higher-level language 

BASIC 

Monitor 

Resident System Monitor 
on PROM 

Price: $466 kit 

$625 assembled 



altair™ 680b 
16K Static Memory 
Card (680b-BSM) 



The 680b-BSM 16K memory 
card consists of four 4096 x 8 
bit static memory arrays, an 
Address Select circuit, a Read/ 
Write circuit, and three voltage 
regulators- 

Hardware 

A DIP switch is used for address 
selection (no address jumpers]. 

Test points have been installed at 
important signal outputs for ease of 
checkout and troubleshooting. 

Ferrite beads are used on all common 
supply lines for noise isolation. 

Epoxy solder masks cover areas not to 
be soldered. 

Sockets are provided for all ICs. 

Power: + 16 V (130 milliamps, maximum) 
— 16V (110 milliamps, maximum) 

+ 9V (150 milliamps, maximum) 

Capabilities 

Power consumption of 5 watts or 38 
microwatts per bit. This allows operation 
of two 16K cards without adding a 
second power transformer. 

RAM Access Time* 215 ns., max, 

RAM Cycle Time * 400 ns., min. 

Up to three 6SOb-BSM 16K memory 
cards may be used with the Altair 680b. 

Price: $685 kit 

$865 assembled 
price includes software 
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altair™ 680b 

UNIVERSAL I/O Card 



The 680b Universal I/O card 
provides two parallel ports and 
one serial port which greatly 
enhance the I/O capabilities of 
the Altair 680b, The design of 
the I/O's two parallel ports is 
based upon a Peripheral 
Interface Adapter (P1AK The 
PIA contains all control and 
data registers, thus most 
options are software 
selectable- These options 
include data direction (each 
data line can act as an input or 
an output) and interrupt/ 
control structure- The design 
of the Universal I/O's serial 
port is based upon an 
Asynchronous 
Communications Interface 
Adapter (ACIA)- The ACIA 
allows serial data to be taken 
in on its receive line and 
transfers the data onto the 
Data Bus, or data can be 
entered from the Data Bus 
into the ACEA and then sent 
out the transmit data line in 
serial form. 

Power: Fully expanded: -t9 unreg. at 
approximately 360 midlamps 
TTY: Receive and Transmit lines 
only: +16v at 44 ma typical 
— 16v at 20 ma typical 
TTY’ Alt input and output lines 

in user +16v at 60 ma typical 
-16v at 60 ma typical 
ACIA not used: +16v at 0 amps 
6v at 0 amps 

RS-232 with maximum inputs and 
outputs: +16v at 0 amps 

— 16v at 4.8 ma typical 
680b MB slots: One. 




Now you can buy an 
Altair 8800 b or an Altair 
680 b computer right off 
the shelf. Altair plug-in 
boards, peripherals, 
software and manuals 
are also available. 
Check the list below 
for the MITS 
dealer in vour area. 


off the shelf. 


RETAIL COMPUTER STORE, INC. 

Tim & Susanne Broom 
410 N£ 72nd Si 
SEATTLE, WA 98115 
(2061 524-4101 

COMPUTER KITS (S F area) 

Pels Roberts 
1044 University Awe 

BERKELEY, CA 94710 

(415)845-5300 

THE COMPUTER STORE 
(Arrowhead Computer’ Co.) 

Dick Heisor 
820 Broadway 
SANTA MONICA, CA 90401 
(213) 451-0713 

gateway electronics. INC 

George Mensik OF COLORADO 

2839 W 44 th Ave. 

□ENVER. CO 80211 

(303)4 58 5444 

COMPUTER SHACK 
Pete Conner 
3120 San Mateo NE 
ALBUQUERQUE, NM 87110 
(505) 833 8282. 883-8283 


altair computer center 

UO The Annex 

5345 East Forty First St. 

Tulsa, OK 74135 

COMPUTER PRODUCTS UNLIMITED 
Harry & Margaret Mohrmann 
4216 West 12th 
LITTLE ROCK. AR 72204 
(501) 666-2839 

GATE WAT ELECTRONICS, INC, 

Harry & Margaret Mohrmann 
Lou Elkms. Stuart BartfiekJ 
8123-25 Page B'vd 
ST LOUIS. MO 63130 
(314) 427-6116 

CHICAGO COMPUTER STORE 
Lou Van Eperen 
517 TafcOtt Rd 
PARK RIDGE. IL 60068 
(312)823 2388 

THE COMPUTER ROOM 
393B Beau D'Rue Drive 
Eagan, MN 55122 
Dale HagerL Bob Raemer 
(612)452-2567 


BYTE'TRONtCS 
John & Stan Morrow 
Suite 103 
1600 Hayes St 
NASHVILLE, TN 37203 
{615)3294979 

THE COMPUTER SYSTEMCENTER 
Jim Dumon, Rich Stafford, 

Steven Mann, Ron Roberts 
3330 Piedmont Road 
ATLANTA, GA 30305 
{404)231-1691 

THE COMPUTER STORE, INC 
Sid Halhgan 
120 Cambridge St 
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Tiny Basic 

— a mini-language 

for your micro 


Along with pointing out the 
differences between Tiny 
BASIC and standard BASIC, 
Tom offers here some com¬ 
ments and opinions on 
BASIC and structured pro¬ 
gramming. Interestingly, his 
manuscript is one of the few 
we've received which was pre¬ 
pared using a text editor (a 
Model 37 TTY driven by a 
COSMAC 1802 microproces¬ 
sor). It would seem that more 
of us (including myself) 
should be at this stage by 
now. — John. 


Tcm Pittman 
PO Box 23189 
San Jose CA 95153 


I f you have an Altair or 
IMSAI computer or any 
8080-based system, you have 
your choice of several ver¬ 
sions of BASIC. There are 
rumors of BASIC for 6800 
and 6502 within the next few 
months. But these require 
memory — probably more 
than you have with your low 
budget machine. 

The alternative is Tiny 
BASIC . The language is a 
stripped down version of 
regular BASIC, with integer 
variables only — no strings, no 
arrays, and a limited set of 
statement types. It was first 
proposed by Bob Albrecht, 
the "dragon" of Peoples 
Computer Company (PCC) in 
Menlo Park, as a language for 
teaching programming to 
children. The PCC newspaper 
ran a series of articles (largely 
written by Dennis Allison) 
entitled "Build Your Own 
BASIC," suggesting how Tiny 
BASIC might be implemented 
in a microprocessor. The 
important portions of these 
articles have been reprinted in 
Dr. Dobb's Journal of Com¬ 
puter Calisthenics and Ortho¬ 
dontic k published by PCC and 
available in most computer 
stores. 


BASIC 

Before we get into Tiny 
BASIC, let us look at high 
level languages in general and 
BASIC in particular. 

When you program in ma¬ 
chine language, each com¬ 
mand, or statement, repre¬ 
sents one operation from the 
machine's point of view. 
When we think of a single 
concept like, "A is the sum of 
B and C," a machine language 
program to perform this oper¬ 
ation may take several opera¬ 
tions, such as: 

LDA B 
IDA C 
STO A 

A high level language, on 
the other hand, lets you put a 
single human idea into a 
single program statement, for 
instance: 

LET A - B + C 

BASIC is one of a class of 
"algebraic" languages in that 
it permits the representation 
of algebraic formulae as part 


of the language. Other lan¬ 
guages in this class are 
FORTRAN and ALGOL 
COBOL does not generally 
fall in this class (except for 
the "super" versions). 

Of critical importance to 
all algebraic languages is the 
concept of an expression. An 
expression is the program¬ 
ming language notation for 
what we might think of as 
"the right-hand side of a for¬ 
mula." Alternatively, we can 
think of an expression as "a 
way of expressing the value 
of some number which the 
computer is to compute." 

An expression may consist 
of a single number, a single 
variable name (all variables 
are referred to by name in 
high level languages), a single 
function call (discussed in 
detail later), or some combin¬ 
ation of these, separated by 
operators and possibly 
grouped by parentheses. For 
this discussion, when we refer 


to an operator, we mean one 
of the four functions found 
on a cheap pocket calculator: 
addition symbolized by " + 
subtraction by " - multipli¬ 
cation by " * " (we do not 
use "X" because that would 
be confused with the name of 
the variable "X"); and 
division by " / ". (The usual 
symbol for division does not 
appear on most typewriter 
and computer keyboards.) 
Thus, A~B 

C-D 

becomes, in computerese, 

(A - B) / (C - D) 

Here the parentheses are used 
to indicate priority of opera¬ 
tions. Normally multiplica¬ 
tion and division are per¬ 
formed first, then addition 
and subtraction. Without the 
parentheses the expression, 

JSbfi- 

C-D 

would be understood by the 
high level language as, 
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which is not the same at all. 

In BASIC, when an expres- 
sion is encountered, It ts 
evaluated. That is, the values 
of the variables are fetched, 
the numbers are converted (if 
necessary), the functions are 
called, and the operations are 
performed. The evaluation of 
an expression always results 
in a number which is defined 
to be the value of that ex pres* 
sion. 

The first example which 
we discussed showed a simple 
BASIC statement, 

LET A-B+C 

This is called an assignment 
statement, because it assigns 
the value of the expression 
"B + C" to the variable A. All 
algebraic high level languages 
have some form of assign¬ 
ment statement. They are 
characterized by the fact that 
when the computer processes 
an assignment statement, a 
single named variable is given 
a new value. The new value 
may not necessarily be 


different from the old; for 
example: 

LET A*A 

This is also a valid assignment 
statement, even though 
nothing changes. Assignment 
statements are also used to 
put initial values into var¬ 
iables, for instance: 

LET P-3 

Control Structures 

One of the important char- 
acteristtcs distinguishing 
different high level languages 
is the control structure 
afforded to the programmer. 
The control structure is deter¬ 
mined by the various per¬ 
mitted control statements, 
which alter the flow of pro¬ 
gram execution. Normally 
program execution advances 
from statement to statement 
in sequence, although there 
are however, circumstances in 
which this sequence is 
altered. The most common 
control structure allows one 
set of operations to be per¬ 


formed if a certain condition 
is true, and another, if it is 
false. In "structured program¬ 
ming" this is referred to as 
the "IF. . . THEN,, . ELSE" 
construct; its general form Is 
"IF condition is true, THEN 
do something, ELSE do some 
other thing." The full gener¬ 
ality of this control structure 
is not directly available in 
BASIC, but, as we shall see, 
this is only a minor incon¬ 
venience. 

Standard BASIC uses the 
IF ... THEN construct, and 
makes it work something like 
a conditional GOTO: 

IF A>3 THEN 120 

If the value of the variable A 
is greater than three, then 
(GOTO) line 120, otherwise 
continue with the next state 
men! in sequence. Actually, 
the condition to be tested 
consists of a comparison 
between two expressions, 
using any of the comparison 
operators which are given in 
Fig. T. 


In each case, if the compar¬ 
ison of the two expressions 
evaluates as true, the implied 
GOTO is taken; otherwise the 
next statement in sequence Is 
executed. In Tiny BASIC the 
syntax is slightly different. 
Instead of a statement num¬ 
ber, a whole statement 
follows the THEN part of the 
IF ... THEN. The compar¬ 
ison above, in Tiny BASIC, 
would be: 

IF A> 3 THEN GOTO 120 

But we could also validly 
write: 

IF A<-3 THEN LET A-A+IO 

or some such. Note that this 
is not valid in standard 
BASIC. 

The GOTO construct has 
been the subject of contro¬ 
versy in the last few years. A 
strong case has been made for 
#l GOTO-less programming" 
which uses only certain other 
control structures to achieve 
structured programs which 
arc more readable and less 
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= Equality (the comparison is true 

if the two expressions are equal) 

> Greater than 

< Less than 

< = Less or Equal (not Greater) 

> = Greater or Equal 

< > Not Equal 

Fig. 1. Comparison Operators. 


prone to errors. I believe that 
both good and incomprehen¬ 
sible programs are possible 
regardless of the control 
structures used or not used, 
but I seem to be in a minority 
at this time. Suffice to say 
that BASIC is not conducive 
to structured programming in 
the technical sense of the 
term. 

Standard BASIC has one 
control structure which has 
been omitted from Tiny 
BASIC. This is the FOR .,. 
NEXT loop. Normally,,if a 
program requires some se¬ 
quence to be performed 
thirteen times, the following 
program steps might be used: 

10 FOR 1-1 TO 13 

20 ... 

30 NEXT I 

Statement 20 would be exe¬ 
cuted 13 times, with the 
variable 1 containing succes¬ 
sively the values, 1, 2, 3 ... 
12, 13. In Tiny BASIC the 
same operation is a little 
more verbose: 


10 LET I-l 

20 ... 

30 LET I-I-l 

40 IF I<-13 THEN GOTO 20 

but, as you can see, nothing is 
lost in program capability. 


Data Structures 

Standard BASIC also has 
some data structures which 
have not been carried over 
into Tiny BASIC. The only 
data structure in Tiny BASIC 
is the integer number, which 
is further limited to 16 binary 
bits for a value in the range of 
-32768 to +32767. Compare 
this precision with the six 


digit precision in standard 
BASIC, which also gives you 
fractional numbers (some¬ 
times called "floating 
point"). Regular BASIC 
allows arrays, or variables 
with multiple values distin¬ 
guished by “subscripts," and 
strings, which are variables 
with text information for 
values instead of numbers. We 
will see presently how these 
deficiencies in Tiny BASIC 
can be overcome. 

Input/Output 

Thus far we have said 
nothing about input and out¬ 
put, how to see the answers 
the computer has calculated, 
or how to put in starting 
values. These needs are 
accommodated in BASIC by 
the PRINT and INPUT state¬ 
ments. Numbers are printed 
(in decimal, for us humans to 
read) at the user terminal by 
the PRINT statement: 

PRINT A. B + C 

This prints two numbers; the 
first is the value of the var¬ 
iable A, and the second is the 
value of the expression B+C. 
In general, the PRINT state¬ 
ment evaluates and prints 
expressions. It is perfectly 
valid to write 

PRINT 1. 123, 0-0 

although we know in advance 
what will be displayed on the 
terminal. To make our output 
more readable, BASIC per¬ 
mits the program to print out 
text labels on the data. 

PRINT "THE SUM OF 1 + 2 IS”, 3+2 

will display the line: 

THE SUM OF 1 + 2 IS 5 

To feed new numbers 
from the terminal to the pro¬ 


gram the INPUT statement is 
used. 

INPUT A, B, C 

will request three numbers 
from the input keyboard. The 
more popular versions of 
Tiny BASIC have an extra 
capability here beyond stan¬ 
dard BASIC, in that the oper¬ 
ator can type in numbers and 
whole expressions. Thus, if in 
response to the INPUT re¬ 
quest above, the operator 
types 

1+2, 3*<4+5), B-A 

the variable A will receive the 
value 3, B will receive the 
value 27, and C will receive 
the value 24 = 27-3. There¬ 
fore, a program in Tiny 
BASIC, which permits no 
text strings, can display and 
accept as input limited text 
information: 

10 LET Y-l 
20 LET N-0 

30 PRINT "PLEASE ANSWER Y OR N M ; 
40 INPUT A 

50 IF A-Y THEN GOTO 100 
60 IF A-N THEN GOTO 120 
70 GOTO 30 

This little program asks for an 
answer, which should be 
either the letter "Y" or the 
letter “N" (or their equiva¬ 
lents, the numbers 1 or 0, 
respectively). If the operator 
types anything else, the re¬ 
quest is repeated. Obviously, 
this technique will not work 
for something like a person's 
name where any letters of the 
alphabet in any sequence 
must be expected, but it is 
certainly an improvement 
over no alphabetic input at 
all. 

A generalized text output 
capability in Tiny BASIC 
depends on another charac¬ 
teristic peculiar to Tiny 
BASIC and not shared by 
standard. That is the fact that 
the line number in a GOTO 
or GOSUB statement is not 
limited to numbers only, but 
may itself be any valid ex¬ 
pression which evaluates to a 
line number. The program 
which is shown in Fig. 2 
prints A, B, or C, depending 
on whether the variable N has 
the value 1, 2, or 3. Note 
that, if N is out of range, 
nothing is printed. 

The USR Function 

What about the fact that 


there are no arrays? Let u$ 
turn to the USR function for 
a way to store and retrieve 
blocks of data. The remarks 
which follow apply only to 
my version of Tiny BASIC 
and are unique in that 
respect 

The USR function is in¬ 
voked with one, two, or three 
arguments (expressions 
separated by commas within 
the parentheses). The first (or 
only) argument is evaluated 
to the binary address of a 
machine language subroutine 
somewhere in the computer 
memory. The USR function 
does a machine language sub¬ 
routine call (JSR instruction) 
to that address. The user is 
obliged to be sure that there 
is in fact a subroutine at that 
address. If there is not. Tiny 
BASIC (and thus your com¬ 
puter) will execute whatever 
is there. The second and third 
arguments, if present, will be 
loaded into the CPU registers 
before jumping to this sub¬ 
routine. On exit, any answer 
the subroutine produces may 
be left in the CPU accumula¬ 
tor, and it becomes the value 
of the function. Two machine 
language routines are already 
provided with the BASIC 
Interpreter; if S is the address 
of the beginning of the inter¬ 
preter, 

USR(S + 20, M) 

has as its value the byte 
stored in memory at the 
address in the variable M 
(that is, the contents of the 
second argument is evaluated 
to a memory address). Also, 

USR(S + 24, M. B) 

stores the low order 8 bits of 
the value of B into the 
memory location addressed 
by M. The return value of this 
function is meaningless. 

Consider the standard 
BASIC program in Fig. 3(a) 
to input ten numbers and 
print the largest as compared 
to the Tiny BASIC program 
in Fig, 3(b). 

I have used this example 
for two reasons: First, it 
shows how the USR function 
may be used to simulate the 
operation of arrays. Second, 
it is typical of many of the 
applications commonly ad- 
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L0 

IF N*0 THEN IF N<4 THUS COS LB 20*0 

i * toj 

20 

RE TIT Hi,' 


JO 

PRINT "A" 


35 

RETURN 


40 

PRINT hi B*' 


4 5 

RETURN 


50 

PRINT * a C a 


55 

RETURN 



to argue for arrays; however, 
neither real nor simulated 
arrays are required for this 
program! Here is the same 
program, with no arrays: 


10 

LET I-I 

20 

LET L*0 

30 

INPUT V 

40 

IF UV THEN LET L-V 

50 

LET I-J + l 

60 

IF U-IO THEN GOTO 30 

90 

PRINT L 


Summary 

Tiny BASIC is not a super 
language* But, it also does not 
require a super computer to 
run. I've given here only a 
cursory examination of the 
power of Tiny BASIC. A full 
description of Tiny BASIC 
may be found in the I tty 


Bitty Computers Tiny BASIC 
User's Manual. This comes 
with a hex paper tape of the 
program and is available for 
$5 from: Itty Bitty Com¬ 
puters, PO Box 23189, San 
Jose CA 95153, 

There are different ver¬ 
sions for each of the follow¬ 
ing systems, so be sure to 
specify which system you are 
running: 

MG800 with MIKBUG, 
EX BUG, or home brew [ Exe¬ 
cutes in 010008FF); AMI 
Proto board (Executes in 
EQ00-E7FF); SPHERE 
(Executes in 020009FF); 
6502 with KIM, TIM or 
homebrew (Executes in 


Fig . 3, Programs to Input ten numbers and print the largest 
(a) Standard BASIC; (b) Tiny BASIC. 


Fig. 2. Program to Print A, 

8 f or C, depending on the 
value o f N. 

020G-OAFF); JOLT (Exe¬ 
cutes in 10G0-18FF); APPLE 
(Executes in 0300-OBFF); 
KIM-2 4K RAM (executes in 
2QQ0-28FF). 

Although few people have 
paper tape systems, we are 
unable to provide the pro¬ 
gram on audio cassette. But if 
you request it, we will supply 
a hexadecimal listing of the 
program instead of tape 
which you can key In and 
then can save on cassette for 
future use. 

If you hove a small 8080 
system, there are several 
widely differing versions of 
Tiny BASIC in the public 


domain. Most of them have 
been published in Dr, Cobb's 
Journal, which is S10 per 
year from: People's Com* 
puter Company, PO Box 310, 
Menlo Park CA 94025, This 
journal has also published a 
number of games which run 
in Tiny BASIC. 

One final comment. Tiny 
BASIC was originally com 
ceived as "free software" by 
the people at PCC. The 6800 
and 6502 versions described 
in this article are not free; 
they are proprietary and 
copyrighted. Software is my 
only source of income, and, if 
I cannot make it from pro¬ 
grams like Tiny BASIC, I 
won't write them. Please 
respect the labor of those of 
us who are trying to make 
quality software available to 
you: pay for the programs 
you use. * 





10 

LET i-i 

10 

FOR 1*1 TO 

10 

20 

INPUT V 

30 

INPUT Vtl) 


25 

LET V-U5RCS-24.I.V) 

30 

NEXT I 


30 

LET l-I+l 

40 

LET L*V<U 


35 

IF I<-10 THEN GOTO 20 

50 

FOR 1-2 TO 

10 

40 

LET L-USR (S+20, U 

60 

IF L>-VU) 

THEN SO 

50 

LET 1-2 

70 

let l*v(i) 


60 

IF L<USR(S+20,I) THEN LET L-USRfS+20,I) 

SO 

NEXT E 


SO 

let i-iu 

90 

PRINT L 


90 

PRINT L 


Rainbow Computing, Inc. 

(formerly Ruiuhnw Enterprises) 
10723 White Oak Avenue 
Granada Mills CA 91344 
(213) 300-2171 

“The com puter store 
featuring software support.” 

Customized Hardware — 
Software Packages 

Program Conversions & 
Origi iia 1 Progra mm mg 

Expert Consulting, Tutoring 
& Research Services 

Authorized Distributor 
for WAVE MATE 
Microcomputer Systems 


□ ByteBoard -3 



4 common connections per backplane 
pad MINI Ml 2ES/ELI Ml NATES inter¬ 
connection wiring t/16 FR4-tinned. 

BB -3 SI5.50 ©a. $140/dOZ. 

A. F, STABLER CO. 

P.O, BOX 354 

CUPERTINO CA 95014 r 
[408)252-4219 L 
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$7500 5WEEPSTCKES 


Why fi Sweepstakes ? 

While many of us gel used to seeing mail order 
sweepstakes contest envelopes (and throwing them 
out), the fact is that there are very few of us who will 
not even lake a chance on winning an extra com¬ 
puter. And that is what is at stake this time . ,. first 
prize is the new Altaic 8800b computer, completely 
assembled and running with 16K of memory. That 
would look awfully good on your desk, wouldn't it? 


Good Chance To Win! 

With over 250 prizes, your chances of winning 
are a lot better than astronomical ,. . after ali, the 
hobby computer field issr/// pretty small. Without an 
entry in the hat you have no chance. 


how Does [iBIMl&IHSlI Win ? 


A marine needs three prime components to 
succeed ... raiders, a continuing source of good 
articles to keep the readers happy, and advertisers. In 
turn, without the readers, the advertisers will go 
away. It’s a great synergistic system. A sweepstakes 
contest draws attention to the magazine and gets 


readers to at least try the magazine. From there on 
the articles have to be good or, as many magazines 
have found (and are finding) out, the readers will 
gradually go away . , . and so will the ads. 

how Do More Readers 
help You ? 

The more readers a magazine has, the more 
advertisers it will attract. And the more advertisers, 
the more pages of articles that can be published. 
Thus, the more readers you help us get, the fatter the 
magazine you'll get every month. A recent issue of 73 
Magazine ran to 288 pages! 

how Can You help? 

Make copies of the Sweepstakes coupon and 
have friends send them in (hopefully with subscrip¬ 
tions). Make sure anyone with a good article brewing 
knows that Kilobaud is the best payer in the field . . . 
we want to have the very best articles available. Pass 
the word at work (if you arc around computer 
oriented people), at school, or around the club. Help 
us make Kilobaud a great big fun magazine. 























HERE ARE THE PRIZES! 



Over 

250 

PRIZES 

to be 

given 

away! 


With over 250 prizes being 
awarded in the Kilobaud Sweep- 
stake^ you have to be at the 
bottom of your luck cycle to 
miss out completely. Just send 
in the card and your chances are 
good. And to make it more 
interesting, every week tilt the 
drawing, welt pull a card out of 
the hat for a Life Subscription 
to Kilobaud. So, the sooner you 
gel your card in the more 
chances you'll have to win. 


ALT AIR 8800b 

That's right, first prize is a 
completely assembled and tested 
Altair 8800b not a kit. The 
Altair, the first really good 
computer available, has become 
the standard - a recent count 
showed over 100 different 
boards designed to plug into it! 
And software? The 8800b is 
almost a year ahead of every* 
thing else no system has morel 



In addition to the 8800b 
system you will get one of the 
brand new MIT5 16K memory 
boards - just what you need to 
give you plenty of room for 
extended Basic and workspace. 
Altair Basic is the one by which 
others are being measured, 
A46GZ 

Win the Ohio Scientific CPU 
Expander, Z80 & IM6100 in* 
eluded. Run POPS, 8080, Z80 
programs on your 6502 (model 
400) system. 

PROGRAMS 

Win a set of 15 game pro¬ 
grams for your 6800 by Techni¬ 
cal Systems Consultants — 
enough to keep you busy for a 
long time. 

BOOKS 

200 copies of ,L Hobby Com¬ 
puters Are Here" ($5) will be 
awarded this is a fine book to 
bring newcomers up to speed, 
particularly In hardware. It is the 
best selling computer book to¬ 
day. 


LIFE SUBSCRIPTIONS 
Twenty of these $150 Life 
Subscriptions to Kilobaud will be 
awarded during the Sweepstakes 
contest - this alone is worth 


sending the card. If you are a 
subscriber and win a Life Sub¬ 
scription you will get back 
double your original subscrip¬ 
tion money. 


SEALS BOARDS 
There will be two lucky win¬ 
ners of the Seals 8K ** never 
forget" memory boards - with a 
keep-alive circuit to protect the 
memory in case of a power 
failure or a flicked switch 
(oops!). Compatible with the 
Allair and Imsai systems. 



Why a contest? We want to 
get your attention — did you 
ever see a parade without a big 
brass band up front? Kilobaud is 
going to be a big and fun maga¬ 
zine and we want you to read it 

— and subscribe. 

You don't have to subscribe 
to enter the contest, but we're 
sure hoping you f ll give it a try. 
Tell you what - if you find that 
you are willing to do without 
Kilobaud we'll grudgingly refund 
the unused part of your sub¬ 
scription {you don't think we're 
going to be cheerful about it, do 
you?). You'll like it — our 73 
Magazine is enormously popular 

- you'll like Kilobaud, 



SOUTHWEST TECH 6800 

Win a Southwest Technical so good you'll start trying out 
Products 6800 kit complete with the parts on the boards and a 
8K of memory and the new little while later find yourself 
Basic compiler. This is one ol making the last solder connec- 
thc finest 6800 kits you can get lions. Thousands of hobbyists 
fun to build and a solid are happy with their SWT 6800 
performer. The instructions arc computer systems. 


Sweepstakes Entry Blank 

noil 

■ - |rwll 

1 have the following systems running: 

1 Enter my oCtt 

| Done year $t5 m subscription to Kilobaud. 

1 w ^ * ■ nj year S26 * subscription to Kilobaud. 0^ ™ 

AND make sure my name is in the hat for the Sweepstakes drawings. Start with issue #?, 

r D/VOr ... No subscription as yet, but put my name in the hat anyway for the Sweepstakes, 

; □ I'm already a subscriber, enter my name in the Sweepstakes, 

Charge to: Q Master Charge D BankAmericard □ American Express D Bill Me 

Card# Interbank # HjHlMM 

1 am working on the following: 

1 would like to read about — 


1 E«p1raflnn riam Sign al Lift? „ 

l have so far invested about $ 


j Name 

Address 

My budget next year is $ 

City State Zip 

“U.S. & Canada only — others please add S2/yeor for foreign posiage. 

| Call TOLL FREE (800) 258-5473 or (800) 251-6771 - SUBSCRIPTIONS ONLYI 

Would ynu lilt* an arfirlfl nn - 







































Reo W. Pratt 
1370 San Caries Ave. 
Concord CA 945 J8 


How a 

Memory Works 


For purposes of definition, 
the addressable space of a 
microcomputer is usually 
divided up into smaller blocks 
called “pages." A page is an 
arbitrary dimension and its 
size is determined by the 
design of available compo¬ 
nents and the preference of 
the user. For this discussion 
well divide our 64K into 16 
different blocks of 4K each. 
The easiest way to see this is 
to imagine a square divided 
into fourths (one fourth 
being a "page"), with each 
fourth divided into four 
again. Each of these latter 
fourths will be one of our 4K 
x 8 RAM boards. 


The following article discusses the theory of operation of a particular 4K memory board (Bill 
God bout % to be exact). However, several other manufacturers also offer the same type of 
static RAM , Altair-compatibie boards and the information in this article applies to those boards 
also. Reo Pratt's reason for selecting the Godbout is rather interesting, too. Read on. — John. 


T he new microcomputer 
owner or hobbyist soon 
learns that a microcomputer 
main frame is virtually useless 
for other than basic educa* 
tion without some sort of 
input and output and more 
memory than is normally 
supplied with the average |if 
there is such a thing) micro¬ 
computer kit. This article is 
about one of the basic 
"extras" — memory — specifi¬ 
cally, random access memory 
or RAM. The objective ts to 
give the novice an under* 
standing of the workings of 
one of the 4K x 8 RAM board 
designs currently on the 
market. The kit chosen for 
this discussion is the Godbout 


4K x 8 Econoram. I chose 
this kit for several reasons, 
not the least of which is that 
1 work for Rill Godbout. As a 
consequence, I'm very famil¬ 
iar with this particular kit 
(Besides, Bill would have my 
head if l wrote about some¬ 
one etse's!) I'm not going to 
try to evaluate the Econ- 
oram's performance or 
compare it (I admit pre¬ 
judice), but merely explain its 
operation. 

In covering this subject. 
I'm assuming some knowl¬ 
edge and experience on the 
part of the reader. Hopefully, 
this discussion will help the 
neophyte to understand the 
workings of a memory, but. 


to avoid any long disserta¬ 
tions on basics, I'm assuming 
a familiarity with the binary 
number system and the basic 
gates: AND, OR, NOR and 
NAND. 

The most popular micro¬ 
processor chips currently on 
the market all use an address 
format of 16 parallel bits. 
Simple math tells us these 
CPUs are capable of selecting, 
counting or addressing 
65,536^ separate memory 
locations (2 16 = 65,536). 
This 65,536 is what would 
commonly be referred to as 
"64 K of memory." Unfortu¬ 
nately, this much RAM is 
rarely used by most hobbyists 
because of the expense. 



rfio-1 t 


Let's take a look at the 
physical layout of a4K RAM 
board (Fig. 1). The board can 
be divided into three parts: 
First, at the top, are three 
voltage regulators; then, there 
are 32 IK RAMs, in this case 
2102s: and finally, there are 
10 logic support and buffer 
chips. 

The voltage regulators pro¬ 
vide on-board regulation. 
Common microcomputer 
power supplies produce 8 V, 
but most TTL and memory 
chips require 5 V for opera¬ 
tion. These voltage regulators 
give a constant 5 V at their 
output with anywhere from 7 
to 35 V at the input. 

Notice that there are four 
rows of eight 2102s. Each 
2102 will store 1,024 (IK) 
single bits. The memory is 
organized in the following 
manners: Each row is eight 
chips wide, with 1,024 8-bit 
words per row, and, since 
there are four rows, we have a 
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Fig t 1 . Component layout of the Econoram board,[ 
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4K x 8 memory* it would be 
possible to take the same 
number of chips and reorgan¬ 
ize them into 8K x 4, for a 
4-bit CPU, or 2K x 16 for a 
16-bit CPU. 

Before we can view the 
operation of the entire board 
we need to dig into the 
depths of the 2102 static 
random access memory itself. 
Fig. 2{a) is a logic diagram of 
a single 2102, and Fig. 2(b) is 
the pinout. The memory 
section of the chip itself is 
organized on the column/row 
principle. This gives us a grid 
wherein we may select a par¬ 
ticular location {single bit) by 
simply calling out the column 
and row. This is illustrated in 
Fig. 3* For a memory size of 
1,024 we'll need 32 columns 
and 32 rows (0-31)* Our 
column/row selection cin 
cuitry will consist of five 
input bits each (2 5 = 32}. 
Let's suppose that we wish to 
select the memory location 
marked by the dot in column 
2 f row 5. We would present 
the number 2 ( 000102 ) to 
the column select logic and 
the number 5 (QOIQI 2 ) to 
the row select logic* The se¬ 
lected bit would then be 
outputted to the data line of 
the chip. Just by selecting the 
desired location with only 10 
address bits, we can access 
1,024 different memory loca¬ 


tions which can be written 
into or read out of at will* By 
putting eight of these in a 
row {bank) and selecting the 
same location in each chip 
simultaneously, we can have 
our choice of 1,024 8-bit 
words* This would be a IK x 
8 memory* 

Referring to the 2102 
pinout diagram in Fig. 2(b), 
we see that the 2102 comes 
in a 16-pin package. We have 
now covered 10 of these pins, 
the address lines. The other 6 
are Vcc, ground, data out, 
read/write {which translates 
as read not write), and chip 
enable. Vcc is simply the pin 
that supplies power to the 
memory cells anti logic arrays 
of the chip, and ground is 
self-explanatory* Data in, 
data out, and the R/W line 
will be discussed together. 
R/W is the pin which deter¬ 
mines whether the memory 
location selected is to have 
data written into it or read 
out of it* If the pin is held 
high (logic 1), the chip will 
output selected data to the 
data out line (i.e., a READ 
operation). If this pin is held 
low (logic 0) the chip will 
look for data at the data-in 
line to write into the selected 
memory location. Therefore, 
either a read operation or a 
write operation will always be 
taking place, depending on 



Fig. 3Memory matrix, illustrating how 1024 different 
memory locations may be addressed by ten binary address 
bits. 


the state of the R/W line* 

Pin 13 , the chip enable 
input (CE), is Tri-state* logic. 
Chip enable is an active low 
signal {denoted by the bar 
over the term CE) and is used 
to enable an entire IK bank 
of 2102s. The Tri-state opera¬ 
tion can be explained as fol¬ 
lows: With chip enable high 
(inactive or disabled), the 
data out pin (which is tied to 
the data bus) is in a high 
impedance state. This pro¬ 
vides for good isolation* (The 
high impedance stale is one 
of the three states*} When the 
chip enable signal goes low, 
the data out tine will be 
either a one or a zero, 
depending on the state of the 
addressed location. (And, of 
course, these are the other 
two states*) 

The reason for wanting to 
disable the outputs is this: 
Suppose we have four banks 
(rows) of memory, and we 
want to read one word from 


* Tri-state i$ a registered trade¬ 
mark of National Semiconductor. 


one of the banks. All banks 
have the same bus or data 
lines in common. When we 
present our address to the 
chips, remember that each 
chip uses the same address 
lines* Therefore when we 
address the four IK banks, 
instead of having only one 
bank place data onto the 
eight-bit bus, we have four 
banks* This causes the out¬ 
puts to "fight" each other, so 
we must have some way of 
turning three of the four rows 
off while we're asking the 
other one row for data. Chip 
enable accomplishes this* By 
disabling alt the chips except 
the ones in the row we wish 
to access, we will have only 
one set of memories placing 
data on the bus at any 
moment. The enabling and 
disabling of the desired chips 
at the right time is accom¬ 
plished by addressing logic 
external to the memory 
chips* Chip enable is an 
important part of the address 
structure of the entire board 
(more about that later)* 
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Fig. 4. Schematic of Address, Data in/Data out , and Memory 
Protect logic * 
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Having studied the 2102 # 
we're now ready to look at a 
schematic of the entire board 
(refer to Fig. 4 and 5). There 
are basically three parts to a 
RAM memory; Addressing, 
data in/data out, and read/ 
write. Fig. 4 is a schematic of 
the board addressing and data 
in/data out logic. In the lower 
left corner are the data out 
lines, labeled DOO through 
D07. Notice that signals 
coming into the board from 
the processor are denoted by 
the pointed box. DOI stands 
for data out, bit 1. BP 35 
simply means backplane, pin 
35. Beginning immediately 
above D07 on the left side of 
the page are the address input 
lines from the processor. In 
the right field of Fig. 4 are 
the data output pins from the 
memory to the processor. 
The lower center field is the 
memory protect logic. 

Notice that address bits 
A12 through A15 all go 
directly to two 74LS139$, 
These 75LS139$ contain the 
logic for page and board 
select The "handling" of 
these address bits will deter¬ 
mine where our board is in 


memory. Remember that we 
have divided the total ad¬ 
dressable memory of the 
processor into 16 parts 
(sixteen 4K segments). By the 
use of two jumpers or 
switches on the board, the 
user selects the board's loca¬ 
tion in memory. A 74LS139 
is made up of two separate 
two-line to four-line decoders 
in a single package. A two- 
line to four-line is a logic 
array which selects one of 
four outputs when given a 
two bit input Fig. 5 not only 
illustrates the breakdown of 
the address lines into BANK, 
BOARD, and PAGE selec¬ 
tion, it also serves as a truth 
table for the 74LSI39. 

Suppose we have address 
bits A15 and A14 both equal 
to 01. This will cause the 
outputs at pins 9, 10 and 12 
to be HIGH, and that at pin 
11 to be LOW. Having pin 11 
jumpered to PAGE would 
place this board in the 16 to 
32K addressing range. (PAGE 
indicates active low.) This 
signal is then jumpered to 
enable pin 1 of chip 42, 
which brings us to address 
bits A12 and A13. The same 


logic follows: If inputs at 
A12 and A13 are, for exam¬ 
ple, 00, pin 4 of chip 42 
would be LOW which would 
cause bank SELECT to be 
enabled Address bits 10 and 
11 would then select a partic¬ 
ular IK bank. 

If we assume we now have 
data at the inputs waiting to 
be stored and we've addressed 
the board properly, al l we 
need do is make read/write 
LOW and our data will be 
written into the addressed 
location. The bank select out¬ 
puts of chip 41 go directly to 
the chip enable pins (pin 13 
of the 2102s) in their respec¬ 
tive banks. With pin 4 of chip 
42 held LOW, SELECT at pin 
9 of chip 34 will be LOW, 
causing the output of the gate 
to be HIGH, which in turn 
will enable the inputs of the 
74LS00 NAND gates. Then 
when the processor makes 
memory write (MWRITE- 
BP68) high, the output of 
chip 33 pin 11 will be low, 
causing the data to be written 
into the addressed memory 
location. 

Reading the data stored in 
memory is very simple now 


Address line* - AlS AH A13 A12 All A10 A9 A3 A7 A6 A5 A4 A3 A2 A1 AO 


Deciaal walfiht - 32766 16384 8192 4096 2048 1024 512 256 128 64 32 16 8 4 2 1 

I ‘- - - J 

Address a location within 

1 1023 locations 


0 

0 

1 

1 


0 - 0-1023 (Bank 0) ^ 
1 - 1024-2047(Bank 1> L 
0 - 2048-3071(Bank 2) ( 
1 - 3072-4095(Bank 3) ) 


IK BANK SELECT 


0 

0 

1 

1 


0 - 0-4095 

1 - 4096-8191 

0 - 8192-12287 

1 - 12268-16383 


4K BOARD SELECT 


0 

0 

1 

1 


0 

1 

o 

i 


0-16383 

16384-32767 

32760-49151 

49152-65535 


} 


16K PACE SELECT 


Note: All values 
shown are 
In declssl 


Fig. 5. Breakdown of address lines into BANK, MODULE (Board), and PAGE select functions. 

HSWS HASH! 


HERE COMES 
COMPUTER SHACK 

Kilobaud recently inter¬ 
viewed Mr. John Martin, 
Director of Franchise Sales 
for Computer Shack , fnc. of 
San Leandro, California. In 
fact, we interviewed him so 
recently that you will have to 
wait for next month's issue to 
get full details. 

Anyway, for right now, 
here are some of the things 


talked about: Computer 
Shacks are on the way ... no 
doubt about it. Mr. Martin 
and his associates (formerly 
with IMSA1 and now colo¬ 
cated with them ... but 
separate and distinct corpora¬ 
tions) have been negotiating 
with groups and individuals 
all over the United States 
concerning Computer Shack 
franchises. 

Mr. Martin predicted that 
by the end of 1977 there 


would be between 100 and 
200 Computer Shacks 
throughout the country. And 
that means prices for compo¬ 
nents and systems should 
drop even lower ... due to 
the purchasing power of a 
group as large as Computer 
Shack. 

The pilot store is located 
in Hayward, California, and 
Mr. Martin said that it was 
quite successful. So, here 
comes your chance Mr. 
Hobbyist ... if you have the 
initial investment required 


that we understand how it 
got there. We must present an 
address to inputs A0 through 
A15 which will cause the 
same page, board, bank, and 
chip location to be selected 
MWRITE (BP68) will be 
brought LOW by the pro¬ 
cessor, which will make R/W 
high forcing all selected 
memories to output data. The 
eight selected memories will 
output their data on the 
MEMDOO through MEMD07 
lines. The 74LS38 output 
buffer will be enabled by 
bringing PDBIN HIGH (Pro¬ 
cessor Data Bus In; BP78, 
chip 35 pin 9). 

The last part of the board 
which requires discussion is 
the memory protect circuitry 
shown in the lower center of 
Fig. 5. This is simply a buf¬ 
fered flip-flop, the status of 
which is determined by the 
memory protect and un- 
protect lines at BP70 and 
BP20. If pin 12 of IC33 is 
held low, the read/write line 
will be high so that data 
cannot be written in any 
memory location on the 
board This is the "protect" 
status of the memory. 

I've described here a 
memory board with buffered 
inputs and outputs, a mem¬ 
ory protect feature and 
onboard regulation. There 
are, of course, others avail¬ 
able with slight variations, 
other features, and different 
methods of doing the same 
thing, but this discussion 
should give you a good idea 
of what's going on in this 
type of memory. Good luck, 
and happy remembering. ■ 


(ranging from $15,000 to 
$62,500 depending on loca¬ 
tion), Computer Shack will 
take care of all ... and I 
mean all ... the details of 
starting your very own store 
... training ... location . .. 
advertising ... promotional 
materials ... interior design 
... the whole works ... 
everything you need to open 
your own Computer Shack. 
We'll get details to you in the 
next issue of Kilobaud . 

Bob Leach 
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WHO DARED TO CHALLENGE THE 8080 & 6800 SYSTEMS? 




WE DID! 


VERAS SYSTEMS 
“F-8” 


A COMPLETE SYSTEM 
FOR ONLY S)ICrt 00 


S 709J 


s 459. c 


KIT FORM 


00 


ASSEMBLED and TESTED 


COMPARE STANDARD FEATURES ON BASIC SYSTEMS 

YOU’LL SEE WHY THE VERAS F-8 SYSTEM WINS HANDS DOWN ! * Registered Trademark* of Fairchild and Moiorol 


STANDARD FEATURES 

VERAS F8 

8080 & E080A 
SYSTEMS 

6800 

SYSTEM 

Parallel I/O Ports 

(3) 8 Bit Bidirectional Brought Out To Rear Panel Conn's, 

None 

None 

Serial t/O Port 

R3-232 or TTY Brought Out To Rear Panel Term, Strip. 

None 

RS 232 or TTY 

Interval Timers 

{2) Programmable Interval Timers 

None 

None 

Interrupts 

a) Vectored Interrupt To Location 0090 Hex. 

b) Vectored Interrupt Programmable Location 

c} Two Vectored Interrupts Associated With Interval 
Timers 

d) Total of (4) Interrupts In A User Defined Priority 
Interrupt Structure 

None 

a) 2 Non Vectored 
Interrupts on P 1 A 

b) 2 Vectored S W l ( 

N M 1 

c) Total of 4 Non Pri¬ 
oritized Interrupts 

Built In Mini Operating System 
in ROM For Terminal And 
Memory Debug 

FAIRBUG* 

None 

MIKBUG* 

Loader Program 

Automatic Internal ROM 

Manual Console 
Switches 

Automatic Internal 
ROM 

Static RAM Memory 

1024 BYTES 

None 

2048 BYTES 

Card Rack 

Rugged Alum. Self Contained Card Rack/Plastic Self 
Aligning Card Guides 

Card Supports 

None 

Auxiliary DC Power To 

Power Peripherals 

+5V, “5V, +12V, “12V @ 1 Amp. Ea. Regulated At 

Rear Panel Terminal Strip 

None 

None 

Basic Kit Price 

S459.00 

S539.QQ, S599.00 or 
$840.00 Depending 
On System 

S395.00 


OUR 4K STATIC RAM BOARD FEATURES: (OPTIONAL) 


* On board dflcodmq for any four of 64 pages. » Aodresi and cWn lines are fully buffered. 

* No onboiif cl regulators to causa deal problems f Chassis mounted I -I /3QOO 

* 4K memory boards wi sh connecior, buffers, italic RAM's a sockets are available m kd form ip I 


THE VERAS SYSTEM 


The VERAS System c?o be marfe inio a 
I7K procetsof by merely adding four of our 
opt-onal memory boards, The kit mdudes 

es'erythmcj you need 10 build (lie VERAS F 8 Computer aj desetibed, All boards, connectors, 
switches, discrete components, polypi- supply and tabinei are sup plied. Progra mining manual, 
data bonk and simplified support documentation supplied, 3K Assembler and Editor (paper 
tape or K.C. Sid, cassette) available on requen with minimum order of 8K RAM 


THE CPU 
BOARD 
FEATURES: 


* T wo I O ports each on the CPU and ROM chip make ^2 Lj.kIk enronal TTI unci 

* The Fait bug* programmed storage unn provides the programmer wnh all 
I.'O tuhrPutinus, 11 lows the programmer to alter or display memory, and 
register its contents vu teletype 

* Programmable internal timer is hum mio the ROM chip 

* Rum m clock generator and power pm reset are buiti into the CPU chip 

* There is a Local interrupt with automatic address vector 
t It u expandable to 8SK bytes of memory 

* 20 mil loop and or HS232 interface included. 

* 1 K ul on board 2)02 RAM 

* Sotul inierlflta Dull! mio P&U Chip 

'Fuirbur) is a registered trademark of Fai'chiiil Carp, 


TINY 2 K BASIC (available) OCT. 15,1976 $25 
FULL BASIC (available) DEC. 15,1976 $50 

Computer dealers and hobbyist dub inquiries are invited. ^ in 


Expected delivery time 30 days or less. 


The More Flexible and Expandable 
Computer at a Comparative Price. 


VERAS SYSTEMS 


> 


I Warranty: 90 days on pans and labOT for 

assembled units. 90 days on parts for kits. 
Prices, ipeciflcatipnj, and delivery subject 
to change without notice. 


VERAS SYSTEMS 

A Div. of Solid State Sales, Inc. 

Box 74 Somerville, MA 02143 
(617)547-1461 

i Enclosed is check for S__ 

or □ Master Charge H __ 

U VERAS F S Computer Kit □ Assembled 
□ 4K RAM Board Quantity 

Name 


Address 
Cuy, State 













































When Art Childs was editor of SCCS Interface Magazine one of the things he had high hopes for was a software exchange library 
within the Southern California Computer Society (on a nationwide basis). Unfortunately, the idea never got off the ground. 
When I told him about the Kilobaud Software Library, his eyes did seem to fight up a bit At the end of our discussion we 
concluded that an article dealing with the criteria for submitting assembly-language programs would be in order. Naturally, we 
decided Art should be the one to write it Here 'tis. - John. 


Software Exchange 

... smoothing the rocky road 


Art ChUds 
PO Box 430 
Gtendate CA 91206 

x change of software 
among computer hobby¬ 
ists may be the single most 
important contribution we 
can make toward promoting 
the utility and pleasure of 
owning a personal computing 
system. The easier, or more 
convenient, it is for the 
hobbyist to contribute, dis¬ 
tribute and use software, the 
greater will be the enhance¬ 
ment of our computing capa¬ 
bility. Toward making shared 
software easier to use, I 
would like to suggest a few 
ideas and propose possible 
standards designed to solve 
some of the problems atten¬ 
dant to shared software. 

Few of us have time to 
write all the software we 
might need, and it's unlikely 
that any of us can gain the 
expertise in all areas of pro¬ 
gramming we would need to 
make our own systems as 
versatile as we would like. We 
must each specialize in one or 
two areas, then share the 
results of our efforts with 


those specializing in other 
areas. With the help of 
punched paper tape, cassette 
or floppy disk for media, and 
the assistance of the U.S. 
Postal Service for exchange, 
it's quite likely that within a 
short time we could each 
have a large drawer full of 
useful software. At that point 
however, we would have 
considerable work to do to 
make all that software work 
for our particular application. 
In this article, I will examine 
the obstacles to software 
exchange and propose some 
solutions. 

Communication 

The first and most pressing 
need is communication. We 
need to determine who has 
what, how to obtain it, and at 
what cost. Many clubs have 
informal software exchanges. 
Members can attend monthly 
meetings, bring the results of 
their latest programming 
endeavors to the club pool, 
and select for their own use 
the contributions of other 
members. Although this 
method of distribution works 


fairly well, it has its limita¬ 
tions, the most significant of 
which is determining what is 
available. 

Another limitation is the 
relatively small size of the 
group involved in the 
exchange effort. The active 
members in a club might 
number in the hundreds and 
yet represent only one or two 
percent of the total number 
of hobbyists nationwide who 
would like to participate in a 
software exchange program. 

Yet another problem is the 
de facto standards that tend 
to become regional in nature. 
In the Los Angeles area the 
prime medium of exchange 
has become Tarbell cassette, 
using the same console con¬ 
trol mechanisms utilized in 
most Altair BASIC interpret¬ 
ers, i.e., 

Console Status Port = 00 

Console Data Port = 01 

Console Input Ready = Bit 
0, True Low 

Console Output Ready = 
Bit 7, True Low 

In other areas the medium 
of exchange ranges from 
punched paper tape object 


formats (Intel hex object 
format, binary, baudot, etc.) 
to cassette in one of many 
formats and baud rates avail¬ 
able, to ICOM floppy disk 
format 

One result of the lack of 
communications and stan¬ 
dardization is a frustration I 
am currently feeling. I have in 
my possession a source listing 
of the Livermore Labs Basic 
and would like to share it 
with all who want it — but, 
besides finding the time to 
enter the code and assemble 
it, how do I inform my fellow 
hobbyists it is available? What 
medium of exchange do I 
select for distribution; 
punched paper tape, Tarbell 
cassette, KC standard cas¬ 
sette, and if cassette, what 
baud rate? Or if I use floppy 
disk, should it be a soft- 
sector, IBM compatible 
format (such as ICOM), or a 
hard-sector format (such as 
the Altair), or... ? 

The Communications Solu¬ 
tion 

As this is being written, 
plans are being made at Kilo* 
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baud Magazine by publisher 
Wayne Green and editor John 
Craig to establish a software 
exchange library for the 
personal computing com¬ 
munity. To my knowledge, 
this is one of the first at¬ 
tempts at undertaking such 
an endeavor by an organiza¬ 
tion with the communica¬ 
tions resources necessary to 
accomplish the task. I there¬ 
fore propose the following as 
a solution to the communica¬ 
tions problem of software 
exchange: 

Given that Kilobaud is, or 
will probably become, one of 
the outstanding national 
personal computing publica¬ 
tions, the inclusion of a soft¬ 
ware catalog in each issue 
informing readers of the 
latest additions to the soft¬ 
ware exchange library is 
recommended. This catalog 
should include the following 
for each program listed: 

1. Program name 

2. Author, author's 
address (with permission) 

3. Very brief description 
of program 

4. Machine written for 
(8080, 6800, 6502, etc.) 

5. Language written in 
(Assembly, B ASIC, 
FORTRAN, PLM, etc.) If 
BASIC or other high level 
language, which version? 

6. Memory requirements 

7. Peripheral equipment 
requirements (cassette, 
floppy, line printer, CRT, 
etc.) other than console 
device. 

8. Media available on 
(punched paper tape, floppy, 
etc.) 

Assuming that, like myself, 
you save all your back issues 
of technical publications 
(furniture moving companies 
love us) you will always have 
at your fingertips an index to 
the Kilobaud Software Li¬ 
brary, and at a glance, know 
whether a particular program 
is useful to you on your 
system. 

Source Listing 

A comment here regarding 
the necessity of sources list¬ 
ing is appropriate. If the pro¬ 


gram is written in BASIC or 
another interpreter, the code 
itself is the source listing. If 
on the other hand, assembly 
language or a compiler is 
used, source and object 
become separate entities and 
provide two possibilities for 
the user. If you have the 
compiler required, the source 
is all you need. If, however, 
you don't possess the com¬ 
piler — or an assembler, you 
could still use the object code 
if certain criteria were met 
when the program was writ¬ 
ten. These criteria will be 
discussed later. 

In any case, the source 
code is going to be needed, in 
almost every case, by users of 
programs from the library. 
Therefore, the source code 
should certainly be submitted 
with a program and made 
available to the purchaser. In 
light of this, a ninth item 
might be added to the list of 
catalog data: 

9. Type code available 
(source, object, or both). 

Documentation 

The next problem is: how 
do we use the particular pro¬ 
gram in question? What 
peripherals does it require? 
Does it require operator 
response, and, if so, what kind 
of response does it expect? 
Does it want its numeric 
input to hex, octal, or deci¬ 
mal? How much memory 
does it require? The answers 
to these problems lie in what 
is purported to separate the 
programmer from the coder 
— documentation! 

Before launching into 
detail, let me clarify a rather 
important point. Most of the 
standards suggested here 
apply to programs written in 
assembly language, since this 
is the bulk of my experience 
on 8080-based computers. 
Other than modifying BASIC 
interpreters for friends, I have 
done little more than play 
Star Trek with, much less 
written programs in, BASIC. 
Thus many of the standards 
will appear to be software 
system specifications of a 
sort. 


Documentation is a 
bothersome, but necessary, 
evil. The following sugges¬ 
tions for documentation, 
when used in conjunction 
with the coding standards 
listed below, will provide all 
the information necessary to 
use the program it describes 
and, at the same time, hold 
the length of documentation 
to something less than a 
Hemingway novel. 

1. Description — A brief 
description of what the pro¬ 
gram does and, optionally, 
how it does it. 

2. Language — The lan¬ 
guage program was written in 
(i.e., 8080, 6800, 6502, etc.). 

3. Memory Requirement 
— Expressed in bytes. 

4. Origin Address — 
Address in memory where the 
program commences loading 
and the address of any non¬ 
contiguous memory require¬ 
ments. Also, whether the 
program is relocatable (and 
therefore provided with a 
relocating loader). 

5. User Interaction 
Required — Those steps the 
user must take to run the 
program. For instance, will 
the machine ask questions on 
the console device to which 
the answer may not be 
apparent? 

6. Complete Description 
of any routines called by the 
program which are not 
included, such as standard 
monitor routines; hex-to* 
decimal, ASCII-to-hex, etc. 
Several items are obviously 
missing from this list. Those 
items comprise the coding 
standards mentioned previ¬ 
ously. If we adhere to the 
following when first writing 
the program, the documenta¬ 
tion will be shorter, and we 
will all be able to get back to 


writing our next programs 
that much sooner. 

Input/Output 

To assume that all systems 
use an 80 character-per-line 
CRT for a console would be 
limiting. Even if that were 
true, should we expect that 
all CRTs are addressed to 
port X and are they all inter¬ 
rupt driven? Obviously not 
So how is this problem 
solved, and what are the 
attendant difficulties of 
handling line printer output, 
paper punch output, or cas¬ 
sette input and output? 

One solution might be to 
disassemble the program in 
question, analyze the code 
for input and output instruc¬ 
tions, and either modify the 
code and reassemble or patch 
the object code to fit our 
particular system of hard¬ 
ware. This is a workable and 
educational procedure. But it 
is time consuming. Further, 
good disassemblers written to 
run on the object machine are 
rare. (I had to write my own 
in order to have a truly useful 
tool.) 

Another method would 
involve loading the program 
into your machine and then, 
using an editor program, 
search through the program 
for I/O instructions. Those 
instructions could then be 
modified to conform to your 
particular system. Once again, 
this is time consuming and 
difficult. 

A more practical solution 
is to standardize I/O vectors. 
For those who are unfamiliar 
with that term, a vector as 
used in this context would be 
analogous to a traffic dis¬ 
patcher or perhaps to a road 
map. If you want to drive 
from point A to point B, you 


r 

ORC ADDRI 


BEGIN: JMP START 


Cl 

JMP ADDR2 

;Console Input vector 

CO 

JMP ADDR3 

;Console output vector 

RI 

JMP ADDR4 

;Tape reader Input vector 

P0 

JMP ADDR5 

;Punch output vector 

L0 

JMP ADDR6 

;Line printer output vector 

KI 

JMP ADDR7 

;Cassette Input vector 

K0 

JMP ADDR8 

;Cassette output vector 

FI 

JMP ADDR9 

:Floppy input vector 

FO 

JMP ADDRA 

;Floppy output vector 

A1 

JMP ADDRB 

jAuxiliary or special purpose vectors 

A2: JMP ADDRC 


A3: JMP ADDRD 



Program (A) 
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BEGIN: 

ORG ADDRl 

JMP START 


Cl: 

JMP ADDR2 

;Console input vector 

CO: 

JMP ADDR3 

;Console output vector 

RI: 

JMP ADDR4 

{Tape reader input vector 

P0: 

JMP ADDR5 

;Punch output vector 

L0: 

JMP ADDR6 

;Lino printer output vector 

KI: 

JMP ADDR7 

iCasaette input vector 

KO: 

JMP ADDR8 

iCasoettc output vector 

FI: 

JMP ADDR9 

{Floppy input vector 

FO: 

JMP ADDRA 

{Floppy output vector 

{Auxiliary or special purpose vector 

Al: 

JMP ADDRB 

A2: 

JMP ADDRC 

{Auxiliary or special purpose vector 

A3: 

JMP ADDRD 

{Auxiliary or special purpose vector 

CPMSC: 

JMP ADORE 

{Console message output routine 

ATOM: 

JMP ADDRF 

{ASCII to hex conversion routine-2 characters 

NBL: 

JMP ADDR10 

{ASCII to hex conversion - single character 

HTDA: 

JMP ADDRll 

;Hex to ASCII conversion routine 

CONV: 

JMP ADDR12 

{Hex to ASCII - Single Character 



Program (8) 


CPMSC: 

MOV B,M 

{Hove number of byteo in nog into B (char counter) 
;lncr K6.L to point to 1st char in asg 

MSGA: 

I NX H 


MOV C,K 

CALL CO 

{Move char into C reg for output 


{Call console output routine 


DCR B 

;Docredent character counter 


RZ 

{Rotum to oain prograa if char counter - 2 ero 


JMP MSCA 

{Jusp back to output another character 

MSC1: 

DB 17 

;Sl 2 e of message (rnaaber of characters) 


DB: 

‘'This la a message" 

Program (C) 


MSGl 

DB 

17 11 


DB 

54 48 49 53 20 49 53 20 41 20 



4D 45 53 53 41 47 45 



Program {D) 


AT0H: 

ORG ADDR1 

MOV A,B 

;Gct high order character 


CALL NBL 

{Convert to hex 


RC 

{Invalid (Return if carry set) 


RLC 

{Rotate to upper nibble 


RLC 

RLC 

RLC 

MOV B.A 

{Save 


MOV A,C 

;Gcc low order character 


CALL NBL 

{Convert to hex 


RC 

{Invalid 


ORA B 

RET 

SUI 30H 

{Combine with high order and clear carry 

NBL: 

;Lces than ASCII "0"? 


RC 

;Yes—Invalid 


ADI 0E9H 

{Greater than ASCII "F"? 


RC 

;Yes—Invalid 


ADI 6 

;Char-A-F? 


JP NBLA 

;Yes 


ADI 7 

;Char-(3A)H through 4OH 


RC 

; Yes—invalid 

NBLA: 

ADI 10 

{Adjust 


ORA A 

{Clear carry bit 


RET 

Program (E) 


simply follow the road on the 
map to point B. A software 
I/O vector helps a program 
arrive at the point that will 
accomplish the particular task 
required The mechanism is 
quite simple. 

Assuming each person 
knows his own machine and 
has already written the neces¬ 
sary software to handle his 
I/O devices, all that is neces¬ 
sary is to direct the program 
to the appropriate I/O rou¬ 
tine. This is done with a jump 
instruction which causes the 
program to execute the I/O 
code written for the host 
machine. For instance, when 
programmers want to put out 
a character on the console, 
they load the output char¬ 
acter Into the C register in 
hex ASCII representation and 
call location X. Users, 
knowing that the output 
character will be in ASCII in 
the C register (for 8080 
machines), write their console 
output routine accordingly. 
Also, knowing the program 
will look for the required 
routine at location X, they 
will put a jump instruction at 
location X which will vector 
(point) the program to the 
output (or input) routine. 
Further, if all I/O routines are 
terminated with a return 
instruction, the writer needs 
only to "CALL" location X. 
All that remains is to define 
X. 


- EXCH 

ANGE PROGRAM -j- 

- USER I/O RO 

UTINES 



1 

(Host Machine RetiOent) 

Suppose the first 14 lines 


ORG 1 



of code in all programs were 

-•-BEGIN: JMP START 

r—J--CO: IN 

00 —\ 

written as in Program (A). 

Cl: 

| ANI 

80—| 

Because documentation 


-CO: JMP BBBB-- 

| Ljm Z 

CO 

accompanying the program 


RI: ! 

Lmov 

A.C-J 

gives the starting address, the 


1 

etc. . 

1-OUT 

01—j 

recipient of the program now 




L ret - 


makes a few simple modifica¬ 





- 

tions which allow the pro¬ 




Cl: IN 

00 

gram to run on his system. At 


Main Body of Program j 

ANl 

01 

location START plus 4, he 



JNZ 

Cl 

lays in the address of the 



r- 1 i 

■— Instruction-t 1 

IN 

01 

console input routine which. 



■ ^ 1 

RET 


hopefully, resides in ROM or 



L-lmtruction-^ ! 



PROM or is at least loaded to 



•-CALL C0-| { 



the same address each time he 


(»> Instruction-* j 

RI: _ 


brings up his system. At loca¬ 


1- 1 \ 

^Instructionj 

— 


tion START plus 7, the 


| 

— 


address of his console output 


1 

etc. 


routine is loaded; at START 


plus 10, the address of his 
Fig. 1. Exchanged and user program interface. paper tape reader input rou¬ 


tine is loaded, etc. (See Fig. 
1). The ideal, of course, 
would be for everyone to 
locate his I/O routines at the 
same location, but computer 
people, being highly individ¬ 
ual creatures, will not likely 
accomplish that soon, if ever. 

For this standard to work, 
we must add a couple of 
attendant rules. First, an 
output character must always 
be handed to the output rou¬ 
tine in the C register. It could 
just as well be the B register, 
or the D or E, for that 
matter, but the D and E are 
more useful as program 
indexes than are B and C, so 
using the C register is less 
disruptive to good coding 
technique. Also, the C regis¬ 
ter has become a de facto 
standard in many areas. Many 
of Intel's programs, for 
instance, are coded that way. 
There are other techniques. 
However, everything con¬ 
sidered, using the C register 
seems to be the best option 
(and is therefore my pro¬ 
posed standard). 

The second rule is that 
input data will always be 
returned in the A register. 
The reason is because the 
data input from a port 
appears in the A register and, 
hence, wouldn't require any 
further manipulation by the 
input routine. 

External Routines 

External routines usually 
refers to code not included in 
the program. This code gen¬ 
erally includes standard 
conversion routines found in 
most good monitors such as 
ASCII to hex, hex to ASCII, 
hex to decimal, decimal to 
hex, random number genera¬ 
tors, console message output 
routines, console parameter 
input routines, etc. Using 
these routines when coding a 
program can often save a lot 
of time and work. For one 
thing, the routine is already 
debugged and working, and, 
for another, a simple CALL 
statement (or a JSR for 6800 
machines) is all that is neces¬ 
sary to utilize the existing 
code. Thus the third part of 
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HTOA: 

MOV B,A 

;Save hex value 


RRC 

RRC 

RRC 

RRC 

{Rotate to high order nibble 


CALL CONVj 
MOV C,A 

;Convert high order nibble 


MOV A.B 
CALL CONV 
MOV B.A 
RET 

;Restore hex value 

C0NV: 

ANI 0FH 

jClear upper 4 bits 


ADI 90H 
DAA 

;Set for carry If A through F 


ACI 40H 
DAA 

;Add carry and adjust 


RET 

Program (F) 


CALL HTOA 

;Wlch value In A register 

CALL CO 

;Output high order 

MOV C.B 

;Gct low order 

CALL CO 

;Output low order 


Program (G) 


ORG 

XXXX 

;Where XXXX is the M 0RG” address plus 3 

JMP 

AAAA 

;Where AAAA is the address of your con¬ 
sole Input routine 
;Whero BBBB is the address of your 
{console output routine 

JMP 

BBBB 

JMP 

CCCC 

;Etc. 

Program (H) 


my proposal is: 

1. Define and publish 
standard routines for perma¬ 
nent residence in all 
machines. 

2. Utilize the routines 
specified via software vectors. 

3. Add the necessary 
vectors immediately after the 
I/O vectors. 

Should the second half of the 
proposal be acceptable, the 
start of every program might 
appear as in Program (B). 

Because establishing any 
system of standards is a 
lengthy and difficult task, we 
have limited our proposal to 
three used most frequently 
standard conversion routines. 
Hopefully, by limiting the 
initial standardization 
attempt to documentation, 
I/O routines, and just three 
additional routines, these 
standards will enjoy a greater 
chance of being accepted and 
implemented. The proposed 
standard console message rou¬ 
tine is coded in Program (C). 
To utilize this routine, the 
programmer simply loads the 
address of the byte contain¬ 
ing the number of characters 
in the message into the H and 
L registers and, if necessary, 
saves the contents of the B 
and C registers on the stack: 


LX I 

H.MSC1 

PCSH 

B 

CALL 

CPMSC 

POP 

B 


The data actually stored at 
the memory location labeled 
MSG1 is shown in Prog. (D) 
This coding technique gives 
the programmer complete 
freedom to output a message 
up to 256 characters long and 
to locate that message itself is 
short, which is important to 
those who wish to store their 
utility routines or their moni¬ 
tor in PROM or ROM. 

The proposed ASCII-to* 
hex conversion routine is 
shown in Program (E). 

1. Move the first, or high 
order, character to the B 
register and the second, or 
low order, character to the C 
register. 

2. Call ATOH. 

3. Upon return from 
ATOH the A register will 
contain the hex value repre¬ 


sented by the two characters, 
if the carry bit is not set 
(carry = 0). If the carry bit is 
set to 1, one of the two 
characters did not fall within 
the range 0 through 9 (30H 
through 39H) or A through F 
(41H through 46H). 

Routine NBL may be used 
for converting a single char¬ 
acter by moving the character 
to the A register and calling 
NBL. Again, the carry bit will 
be set if the character is not 0 
through F. 

Routines which convert a 
binary value in the A register 
to two ASCII characters in 
the B and C registers are 
shown in (F). 

To use the hex to ASCII 
routines, simply put the hex 
value to be converted into the 
A register, call HTOA, and 
retrieve the high order char¬ 
acter from the C register and 
the low order character from 
the B register. You will note 
that the results of the conver¬ 
sion have been put in the B & 
C registers in seemingly 
reverse order. This was done 
to facilitate output which 
uses the C register as a com- 
munication device. An 
example: Program (G). 

Conclusion 

For any system of stan¬ 
dards to be effective it must 
be agreed upon by a large 
portion of all possible users 
and then adhered to. This is a 
lot to ask of the individuals 
currently involved in personal 
computing, and probably 
even more to ask of the 
va r ious m anufacturers 
marketing equipment to the 
hobbyist. But, should the 
implementation of these 
standards take place, the 
rewards for all will be well 
worth the effort. 

If we in the personal com¬ 
puting community wish to 
put forth the time and effort, 
we might eventually place 
into widespread use an oper¬ 
ating system monitor which 
includes utility routines, such 
as those described above, as 
well as others for all of the 
most widely used micro¬ 


processors (including 8080, 
6800, 6502. Z80, 2650, F8, 
and others). Further, if the 
manufacturers care to cooper¬ 
ate, the monitors could be 
located at the same address in 
all machines, thereby elimi¬ 
nating the need for the soft¬ 
ware vectors described earlier. 

To accomplish this, I 
suggest a standards con¬ 
ference perhaps similar to the 
Kansas City conference that 
produced the KC Cassette 
Standard, but much broader 
in scope. 

In the meantime, for those 
who care to join me in 
implementing a minimum 
software coding standard for 
the 8080, here is a tip to 
easily utilize the I/O vectors 
and the utility routine vectors 
described earlier in the arti¬ 
cle. 

Upon receipt of a piece of 
software conforming to these 
standards, ascertain the 
"ORG" (origin) address, and 
assemble the code in Program 
(H). 

(For complete listing, refer to 
Listing under "External 
Routines.") 

After loading the received 
program, simply load your 
vectors on top of it (or 
append your vector object 
code to the program object 
code). Save your vector 
source code so that, by 
merely changing the ORG 
value to fit subsequent pro¬ 


grams, it need not be 
recoded, only reassembled. 

I propose two final sugges¬ 
tions for this standard. The 
first, which applies to all 
machines, is to leave adequate 
room to add more vectors as 
required in the future. This 
can be easily accomplished by 
coding the first statement in 
the program (the JUMP 
instruction at the label 
BEGIN) as: JMP 100H. This 
will allow for a total of 63 
I/O and utility routine vec¬ 
tors which should be more 
than enough. 

The second suggestion 
applies only to 8080 and Z80 
machines, utilizing RAM 
addressed at location 0. Make 
the address of label 
"BEGIN"=40H, thus leaving 
free all 8 interrupt addresses 
for use by those whose 
systems employ interrupt 
driven I/O. 

Other Machines 

My prime area of interest 
is in systems and utility pro¬ 
gramming for the 8080 and 
Z80, thus I've yet to educate 
myself sufficiently in other 
machines to propose ade¬ 
quate utility routines. I 
would therefore like to invite 
those whose prime interest is 
in 6800, 6502, or other 
microprocessors to write up 
their suggestions and join me 
in the crusade for more useful 
software. ■ 
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This is the first in John 
Moinar's series on practical 
microcomputer programming. 
And, the use of the word 
"practical" is very appro¬ 
priate because he has come 
up with some good examples 
to illustrate the use of logical 
instructions in the following 
article. (Be sure and catch his 
article on a proposed hob¬ 
byist operating system next 
month.) John is currently 
writing a book dealing with 
microcomputer programming. 
Should be a good one. — 
John. 

L et's face it! The so* 
cal I ed "m icrop rocessor 
revqlution" is well under 
way. A random glance 
through any electronics maga- 
zine will reveal a wealth of 
articles and advertisements 
aimed at the home computer 
market The microcomputer 
experimenter has a wide 
range of hardware to choose 
from ranging from simple 
"CPU prototype boards" all 
the way to elaborate systems 
complete with color graphics 
CRT display. Applications for 
micro based systems are also 
never ending; radio amateurs 
have developed systems to 
control complete radio tele* 


type (RTTY) stations and 
antenna headings, while, at 
the other end of the spec¬ 
trum, computer game freaks 
search for the perfect TREK 
program. And, of course, 
there are the classical com¬ 
puter applications, such as 
bookkeeping and inventory 
control. The key to the suc¬ 
cessful computer application 
rests only partially with the 
hardware system. Unfortu¬ 
nately, the major problem en¬ 
countered by the computer 
experimenter is programming, 
that seemingly hopeless task 
of making the bits, bytes, 
registers, and instructions per¬ 
form together to make an 
application work as well as it 
should. More often than not, 
the hardware assembly and 
debug of a micro system is 
the easiest part; the problems 
occur when the system is to 
be used. Compare a micro¬ 
processor kit, such as the 
SWTP 6800 and a Heath 
stereo amplifier. Once com¬ 
pleted, the amplifier need 
only be plugged in and con¬ 
nected to other components 
to be enjoyed — the com¬ 
puter does nothing when 
completed until programmed 
by its user — a difficult task 
for the individual unfamiliar 


with the art of programming. 
To the uninitiated and inex¬ 
perienced, programming is 
bewildering at best and down¬ 
right frightening at worst 

It is the intent of this 
article, the first of a series, to 
lift some of the shroud of 
mystery concerning micro¬ 
processor programming. 
There are countless tips and 
techniques that, once under¬ 
stood, can make the software 
end of microprocessors as 
enjoyable as the building and 
testing of the kit 

It is assumed that the 
reader is familiar with the 
architecture of his or her 
particular micro, the registers 
available, the instruction set, 
and the data paths. Most 
micro systems today are pro¬ 
grammed in assembly lan¬ 
guage, using the machine's 
actual machine code to 
develop the program. Al¬ 
though "high-level" language 
processors, such as BASIC, 
are available for some micros, 
techniques learned through 
assembly language program¬ 
ming can always be carried 
forward 

This article specifically 
covers use of the logical in¬ 


structions AND, OR and 
EXCLUSIVE OR. Beginning 
programmers seem to mi* 
u nderstand, and therefore 
avoid, these powerful instruc¬ 
tions. This is unfortunate, as 
many programming shortcuts 
and algorithms are based on 
the logical instructions. Hope¬ 
fully, this discussion will 
allow the programmer to 
bridge the gap between 
simply using the micro¬ 
processor to add numbers and 
the development of meaning¬ 
ful software. The examples 
presented are written in 
Motorola M6800 assembly 
l a nguage. The techniques, 
however, are definitely appli¬ 
cable to any micro instruc¬ 
tion set that includes logical 
instructions. All the examples 
have been tested for accuracy 
on a Motorola 6800 system 
and the reader is invited to 
duplicate, modify and hope¬ 
fully understand them on his 
or her own system. 

Logical Instructions Allow 
"Bit Manipulation" 

Computer instruction sets 
usually allow four types of 
operations: arithmetic , 
input/output, control, and 
logical. The first three classes 
are somewhat self-explana¬ 
tory, especially after reading 
the programming manual 
packed with the micro kit 
However, the logical instruc¬ 
tions are often presented with 
a "truth-table" discussion 
involving a maze of ONE and 
ZERO bits that seemingly tell 
all — that is, all but what they 



Fig. 1. Logical Operations 
Block Diagram. fNote: the 
value to be compared in the 
Accumulator and the mask 
value are interchangeable.) 
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do and how to do anything 
useful with them! The key to 
understanding logical instruc- 
tions is to remember that 
they deal with single bits 
within a computer register or 
memory location as opposed 
to the arithmetic operations 
that produce a result based 
on the entire contents of a 
location. In an eight'bit micro, 
one logical instruction pro¬ 
duces eight individual 
"answers," one for each bit in 
the computer word. We will 
show that the capability of 
manipulating single bits pro¬ 
vided by the logical opera¬ 
tions is the key to a multi¬ 
tude of programming tech¬ 
niques usable in every 
program. 

The AND Function — 

or. It Takes Two to Get One 

All logical functions work 
by comparing two bits in 
different locations to produce 
a single bit answer that re¬ 
places one of the original bits 
{see Fig. 1). The bits com¬ 
pared occupy the same posi¬ 
tion in each of the respective 
locations, bit position 0 in 
word t is compared to bit 0 
in word 2, etc. The target 
location for the answer is 
usually a computer register. 
With this in mind, let's look 
at the first of three possible 
bit comparisons, the logical 
AND function. The rules for 
the AND are expressed in 
truth-table form in Fig. 2. 
Note that in order to produce 
a 1 result both of the com¬ 
pared bits must be Is. A zero 
condition is produced if 
either or both of the com¬ 
pared bits are 0. It is most 
important to recall that eight 
unique answers are produced 
by a single AND instruction 


El 17 X BIT 2 

result 

1 l 

l 

C 0 

0 

1 1 Q 

0 

l 

0 


Fig. 2. AND function truth 
table. 


in an eight-bit micro. The 
state of any bit adjacent to 
the bits compared does not 
affect the result. Fig. 3 illus¬ 
trates a simple program which 
loads the G800 A register 
with the hexadecimal value 
31, the ASCII representation 
of the printable character 1. 
(This example illustrates an 
important programming func¬ 
tion allowed by the AND 
operation, that of masking,) 
Memory location 20 (hex) is 
initialized with the value OF. 
The AND A MASK instruc¬ 
tion performs a logical AND 
between the contents of the 
A register and the contents of 
location 20 (designated 
MASK), The result, 01, is 
placed in the A register. If 
you don't have the capability 
of actually executing the 
sample program, lay the bits 
out on paper and perform an 
AND function, bit by bit. 
Your results should be the 
same. 

It is often useful to isolate 
certain bits within a word 
while discarding (setting to 
zero) the remaining bits. 
An everyday programming 
example illustrates the point: 
The ASCII code, a means of 
representing data in a com¬ 
puter on external peripherals 
such as a TTY, is not usually 
suitable for internal computer 
operations. Table 1 shows the 
ASCII representation of the 
letters and numbers. Note 
that the ASCII value of the 
characters increases by one 
while progressing upward 
through the letters and num¬ 
bers. This collating sequence 
is useful when we wish to 
compare ASCII data in com¬ 
puter programs, as the value 
for the letter B is less than 
that for C, etc. Also note that 
in order to represent the 256 
possible ASCII characters it 
takes eight bits per character, 
many more than necessary if 
a program needs only to 


LOCATION 

CODE 

INVTMJCnON 

COMMENT 

00 

£6 31 

EM A.4J1 

A REGISTER - GIAKAiTEK 

02 

c& or 

im i.sor 

‘yASK 4 VAULT TLl r. K'litSTCR 

04 

F7 00 

5TA 

rAEK TO UOCATUC . ’ 

0? 

B4 0L< 

A k £> AjMKK 

STRIP STTK •*- f 


3F 

SKI 

STOP 



K* i 

yAsi laancti a*:: kj* s^xltes 


Fig. 3 ; Program using AND instruction to isolate bits 0-3 in the 
A Register. 
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Ctfi! 0000 


31 

OuU juui 


32 

0011 f.OlO 

1 

n 

oou oou 

9 

h 

oy u \m 

A 

hi 

OtttJ 0001 

ft 

4 1 

UHJLI OULU 

G 

43 

oioo mi i 

0 

§r 

oioo im 


hi 

0101 O010 


& 

UI01 100] 


hk 

0101 ItttO 


Table 7. Partial ASCII character table . Note that ascending 
character values have corresponding increasing numeric value. 
This "collating sequence" is useful when sorting characters in 
memory. 


decode, or detect ten digits 
and 26 letters. The numbers 
require only four bits to 
make them unique, while the 
letters require six. It is often 
desirable to "strip" the un¬ 
used bits from characters to 
make program calculations 
easier. Masking , using the 
AND instruction, simplifies 
the process of removing the 
undesired bits. It works like 
this: To save the desired 
portion of an ASCII byte, set 
the appropriate bits in the 
MASK to one while re¬ 
setting (zeroing) the remain¬ 
ing bits. This mask byte 
should be in a memory loca¬ 
tion, not a register, so it will 
remain untouched by the 
AND operation that strips un¬ 
needed bits. Referring again 
to Fig. 3, we find the mask is 
the contents of location 20. 
Each time the A register is 
ANDed against the mask the 
most significant four bits are 


reset and the desired bits 
remain unchanged in the A 
register, A very practical 
example, Fig. 4, illustrates 
this technique. Let us 
visualize an amateur teletype 
operator who desires to con¬ 
trol five station functions by 
using a micro system. The 
code letter A, B, C, D or E, is 
entered at the CRT to select 
the desired routine. In Fig. 4, 
it is assumed that a previous 
routine validated the input 
command character and left 
it in the A register in ASCII 
(eight bit) format. The rou¬ 
tine required must somehow 
cause a branch to the de¬ 
sired computer routine 
RTN1-RTN5 based on the 
input character. Referring to 
Fig. 4, the selection routine 
works as follows: The A 
register i$ ANDed with a 
mask of 07 (hex) in location 
25, resulting in the stripping 
of bits 3-7. Note that the 


LOCATION 

COOE 

INSTRUCTION 

00 

fib 00 ■ 

EM A.awt 

03 

Cb 0/ 

EM R.S07 

O', 

ft O0 , 

n STA R.KASft 

tie 

flA WO . 

.'i Alta A. 

m 

hk 

AS1* A 

DC 

B? 00 , 

,M STAA.QFST*: 

CF 

FT no . 

;; UK 0FSET 

U 

a io 

UK TA5LE.X 

£4 

hf: no 


14 

Hi oo 

Jfr* X 

22 


m, o 

23 


tea i 

24 


Ka 4 

2b 

FtASK 

tea 1 

ira 

oo no 

TAhUv rm o 

11 

oi no 

iVU KE<1 

34 

a? no 

rjh 

34 

0 3 00 

r» m3 

33 

o, no 

rm m** 

Ik 

03 00 

FTKi KIM 


COMMENT 

<nwol::-: A.fi.C.D.Cft K 
HV-K vaus: XQ 
ttASt WtAUitl r> 

fti), HUTS 0’. 1 

shut [joi.jja: vaut; is a sen 

5,v.r mis. 

rerai outset valle 

X*TAHI Wm-HWniE AEGfiESS 

EXIT Tit sn-ECtliO 

o:it ni studcted rcetus 

INITIALLY ZERO 

SAKE UfATlQC FER 0FTSL7 VMLT! 
IKm flftRAlTTK fT* FGH 
s/tatii*; 

t*11 ft AEIftfSS 
HVrtir i assess 
rHTTJ-7 .' ASOESS 

tonm i assess 
Ro.'n it . - Aittess 

taTIKK b ADDRESS 


Fig. 4 , Routine Selection Program discussed in the text. One 
of five routines, RTNl-RTN5 r is selected based upon input 
charac ters A - E. The inpu t cha rac ter is dap osi ted in I oca ti on 24 
by an input routine (not shown h The RMB directives cause 
the assembler to reserve memory bytes for use by executing 
programs. The FDB t or Form Double Byte directive, causes 
the assemb/er to form actual data for the program to use > In 
this case , that data is the address of a routine elsewhere in 
memory called RTNFRTN5, 
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LOCATION 

CODE 

INSTRUCTION 

COMMENT 

00 

CZ 01 00 

LEK MW 

FIRST UXATICK TO QEQC 

03 

C6 40 

LDA B.C40 

MASK VALUE TO ISOLATE BIT 6 

05 

17 LOOP 

TBA 

WSK TO A FOR CKEtX CYCLE 

06 

A4 00 

AM) A. X 

SEARCH TOR BIT 

08 

26 07 

BNE FXXJKD 

HIT. ENTER FOUND ROUTOEl 

QA 

08 

INX 

INCRBeir X TOR IEXT CYCLES CHECK 

0B 

8C 01 80 

CPX 0180 

DONE?? 

0£ 

26 F5 

ME LOOP 

NO. OCWTINE CHECKING 

10 

3F 

FOUND 

SSL 

YES. HALT 

PROCESSING ROUTINE FOR HIT 


Fig, 5, Routine for memory search featuring the AND 
instruction. When memory byte with bit 6 is found, the 
routine exits for additional processing at point FOUND. 


LOCATION 

coot 

INSTRUCTION 

COMMENT 

00 

BA 00 20 

ORA A. $20 

“CRT’ first fattens into a sec 

03 

&V 00 23 

ORA A.$23 

"CSC sbodto pattern 

06 

BA 00 25 

CRA A. $25 

AM) LAST paths:;, procuciic -or 

09 

3F 

SW 

HALT 

20 

41 

FDfi $41 

FIRST PATTERN 

23 

80 

FCB $80 

SECOND PATTERN 

25 

0C 

FCB $0C 

THIRD PATTERN 


Fig . 7. Example of logical OR function used to combine bit 
patterns into single register word[ The final pattern is CD 


ASCII representation of the 
characters A-E in Table 1 
make the resulting A register 
value a binary number in the 
range 001 for A to 005 for E. 
This binary value is the key 
to our selection process. 
Since we want to form the 
address of the desired routine 
and since all addresses in the 
6800 micro are 16 bits in 
length, the eight bit value in 
the A register must be ex¬ 
panded to a 16-bit address. 
This is accomplished by 
shifting the A register one bit 
to the left, effectively doub¬ 
ling the numerical value of 
the A register and producing 
an "address compatible" 
value. (Note: Using the 
SHIFT function of most 
micros is an easy way to 
multiply or divide a value by 
any power of two. The left 
shift multiplies the value by a 
power of two for each shift; a 
right shift divides the value.) 
Assuming that the operator 
entered the character "C" to 
select the third of five rou¬ 
tines, we find the binary 
value in the A register to be 
00000011 after the AND 
operation and 00000110 
after the shift The routine is 
now ready to actually form 
the address of the subroutine 
desired. The A register is 
stored in location 23, loca¬ 
tion 22 having been pre¬ 
viously cleared. The instruc¬ 
tion LDX OFFST then loads 
the values at locations 22 and 
23 into the 6800 index (X) 
register, which is 16 bits 
wide. The hexadecimal value 
in the X register is now 0006. 
A second X register opera- 


BIT 1 

BIT 2 

RESULT 

1 

1 

i ! 

0 

1 

i 

l 

0 

i 

0 

0 

0 


Fig. 6. Truth table for the OR 
function 


tion LD TABLE,X loads 
the X register with the 
address of the desired rou¬ 
tine. Location TABLE and 
the locations following con¬ 
tain the five routine ad¬ 
dresses. The value in the X 
register is formed by the 
internal machine operation 
that adds the existing value in 
the X register (0006) to the 
address of TABLE. Thus, the 
actual value in X is 
TABLE+6, which is the 
address of the third routine, 
the one desired. All that we 
now need is a jump to the 
routine using the X register 
for the jump address. Thus, a 
simple program has allowed 
the transition between an 
input character and the 
routine it represents. This 
example illustrates a simple, 
yet powerful, means of 
directing computer opera¬ 
tions based upon outside- 
world human inputs. The 
only restriction on this pro¬ 
gram is that the TABLE of 
addresses must be within the 
first 256 memory addresses as 
the offset value for a 6800 
index operation is 256 bytes. 
Note that had the AND in¬ 
struction been eliminated the 
offset value before the shift 
would have been 67 instead 
of 3 (the binary value of the 
character C). Step through 
the example, eliminating the 
AND instruction, and see for 
yourself. 

A final practical example 
of the AND instruction is 
shown in Fig. 5. In this 
example, we want to scan all 
memory locations between 
100 and 17F (hex) for any 
byte with a value of 64. 
Knowing that 64 is equal to 
2®, we must check bit six of 
every location for a 1 condi¬ 
tion. The program functions 
by using the AND to isolate 


(Hex) or 11001101. 

the desired bit. Each cycle 
through the loop causes 
successive locations, starting 
at 100, to be checked for bit 
six being set. If this is found, 
control is passed to the 
processing routine FOUND. 
Note that the A register is 
reloaded with the mask each 
cycle, since, in this case, the 
register, not the memory 
location, is altered as the pro¬ 
grams executes. Loop control 
is provided by insuring that 
the X register has not ex¬ 
ceeded the final location 
(17F) each time it is incre¬ 
mented by the I NX instruc¬ 
tion. When the X register 
does exceed 17F, the pro¬ 
gram halts. 

In summary, there are two 
important uses of the AND 
instruction to be remem¬ 
bered: The first is to clear 
undesired bits from a location 
using an appropriate mask; 
the second is to check for the 
existence of a SET bit by 
using a mask with the desired 
bit set. 

The Logical OR — 

Any 1 is a 1 

Observing the truth table 
of Fig. 6, it can be seen that 
the OR operation is the 
opposite of the previously 
discussed AND. When either 
or both of the bits compared 
are 1, the result is 1. The OR 
function also operates on a 
bit by bit fashion within the 
computer word. However, 
this time the mask is used to 
SET any bit in the word. This 
is the primary use of the OR 


function, which is used to 
connect or combine isolated 
bit patterns into one word. 
Fig. 7 illustrates the OR in 
action. Locations 20, 23 and 
25 contain different bit pat¬ 
terns; respectively 01000001, 
10000000, and 00001100. 
The three ORA A instruc¬ 
tions combine the pattern in 
the A register, each pattern 
places its 1 bits into the 
respective bit position in the 
register. The final result of 
the operation is 11001101. 
The capability of the OR to 
set any bit has useful pro¬ 
gramming ramifications. 
Returning to the ASCII char¬ 
acter example of Fig. 4, we 
recall that the AND was used 
to CLEAR undesired bits 
from the character for 
internal processing. However, 
in order to output an internal 
binary value, we must restore 
the correct bits to form a 
valid ASCII character. 
Assume that the binary value 
1001 (9 in decimal) is con¬ 
tained in the lower bits of the 
B register. It is desired to 
output this value to the tele¬ 
type, but the bit pattern 
00001001 is not the correct 
ASCII code for 9 (the correct 
value is 00111001). Hope¬ 
fully, it will now be obvious 
that in order to convert the 
unprintable version of 9 to a 
printable form the two 
missing bits must be added to 
the word. The OR function 
may be used to mask (or add) 
the bits into the word, as 
shown in Fig. 8. A mask of 
00110000 is set up in loca- 


LOCATION 

CODE 

INSTRUCTION 

COMMENT 

00 

F6 00 30 

LEA B.VALLE 

B REG - 1001. A NCK-PRII.TABIX VALLE 

03 

FA 00 20 

CRA B.MASK 

MASK IN VALLE 00110000 

06 

7E 01 00 

JK? PRINT 

JWONC THE RESULT PX INTAKE 

20 

30 MASK 

FC3 S30 

THE M*£K 

30 

09 VALUE 

FCB $09 

INITIAL NON-PRINTING VALUE 


Fig. 8. Example of logical OR function used to mask 
(combine) necessary bits into a binary value representing a 
printable ASCII character. 
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LOCATION 

CODE 

INSTRUCTION 

COMMENT 

0100 

£6 01 20 

UK A. FLAG 

FETCH FLAG WORD 

0103 

BA 01 21 

ORA A.FIGS 

SET DESIRED F1AC BIT 

0106 

B7 01 20 

STA A.FLN3 

RESTORE i\tC UCRD 

0120 

rue 

ra o 

FLAG WORD 

0121 

08 FIGS 

FtB $06 

MASK TO SET ’’FIGS" FL PC 


Fig. 9. Using logical OR to set a flag bit for program control. 


tion 20. This is ORed with 
the B register, producing the 
printable ASCII character 9. 
Note that the OR does not 
disturb existing bit patterns 
when the mask bits are zero. 
This feature suggests another 
OR use, that of maintaining 
program flags . Many times a 
program, when executing, 
requires the capability of 
remembering whether events 
or steps have or have not 
been performed. For 
example, in the radio teletype 
program mentioned earlier, 
the program may need to 
know the mode of the RTTY 
terminal. If the terminal is in 
the FIGS (figures) mode, 
numbers and special char¬ 
acters are printed; when it's 
in the LETS (letter) mode, 
letters are printed. A single 
bit, or flag , may be used by 
the program to determine if 
the carriage requires a shift 
before outputting a data char¬ 
acter. A word called FLAGS 
exists in the program with bit 
three of the word indicating 
the TTY mode. If bit three is 
set, the carriage is in the 
FIGS mode, and, if reset, the 
LETS mode. Assume that the 
program desires to send a 
number to the TTY, requiring 
the carriage to be in the FIGS 
position. Before sending a 
FIGS character, the program 
sets the bit three flag using an 
OR instruction with a mask 


word of 00001000. Now, 
when a later program module 
desires to send a letter, the 
FIGS flag can be checked, 
and, if set, a LETS character 
will be sent to the TTY 
before the data is trans¬ 
mitted. (Question for 
thought: How did the output 
program check the state of 
the FIGS flag? Hint: Possibly 
a previously discussed logical 
function was used!) See Fig. 
9 for practical program 
details. In concluding the dis¬ 
cussion of this example and 
the OR instruction, note that 
the other seven bits in the 
FLAG word are not affected 
when one is set, as long as the 
corresponding mask bits are 
0. The technique of using 
flags to control program se¬ 
quencing is important, as it 
great simplifies the intercom¬ 
munication links between 
program modules. 

And Finally, 

The EXCLUSIVE OR - 
or How to Flip a Bit 


We have just shown that 
the OR function may be used 


BIT 1 

BIT 2 

RESULT 

1 

L 

0 

0 

1 

1 

1 

0 

1 

0 

0 

0 


Fig. 10. Truth table for EX¬ 
CLUSIVE OR (XORI func¬ 
tion. Unlike bits produce a 
ONE result; like combina¬ 
tions a ZERO. 


LOCATION 

CODE 

INSTRUCTION 

COMMENT 

00 

66 48 

UK A.INTT 

INITIAL PATTEK1 - 01001000 

02 

B3 00 20 

EOR A.HASC 

‘•flit pattecj to lononi 

OS 

B3 00 20 

OCR A.HASC 

RESTORE INITIAL PATTEXi 

08 

3F 

SWI 

HALT 

20 

FF MASK 

PCS $FF 

MASK 


ihit 

□QU $48 

INITIAL PATTER! 


Fig. 11. Program example in which the EXCLUSIVE OR 
instruction is used to alternately flip the state of a bit 


to selectively set a bit, a 
useful technique for setting 
program flags. However, in 
order for this technique to be 
effective, a method for 
resetting the flag bit on 
request must exist The last 
of the three logical functions, 
the EXCLUSIVE OR (XOR) 
is used to that end. The truth 
table for the EXCLUSIVE 
OR is represented in Fig. 10. 
The result of a bit compari¬ 
son is a 1 only when the bits 
checked are of different 
states. Either two 0s or two 
Is result in a 0. Thus you can 
see that the XOR function 
can be used to alternately 
SET and RESET a bit in a 
register or memory. For 
example, if the A register 
contains the value 01001000 
and the XOR mask is 
11111111, the EOR A in¬ 
struction results in the value 
10110111 being placed in the 
A register. If the reversed A 
register is again XORed 
against the same mask, the 
original pattern is repro¬ 
duced, ad infinitum. (Refer 
to Fig. 11.) The XOR func¬ 
tion may be used to reset flag 
bits previously set. Recalling 
the example of Fig. 9, the 
FIGS flag bit can be reset by 
using the same mask used by 
the OR instruction that 
originally set the bit. Again, 
note that the only bit altered 


is the one reflected by a set 
mask bit. All the others re¬ 
main unaffected under the 
rules of the XOR. Note: The 
XOR with mask could also 
have been used to set the bit 
originally as long as the flag 
word was initially zeroed 
(which is a good practice, 
anyway). Check it out. 

In Conclusion 

So, that's it for the logi¬ 
cal! The AND, OR and 
EXCLUSIVE OR deal specifi¬ 
cally with bits in a computer 
word, and ... knowing how 
they work, the reader should 
be able to put them to good 
use in individual application 
programs. Liberal use of the 
logicals will result in shorter, 
more efficient programs and 
in many cases save consider¬ 
able debug time when a pre¬ 
viously written area of code 
can be eliminated. In future 
articles the use of additional 
programming techniques will 
be covered, including: the 
condition code , signed num¬ 
bers, sorting methods, and 
routines dedicated to testing 
a new microprocessor and its 
memory after assembly. 
Familiarity with these simple, 
confidence building routines 
will help you develop and 
exercise new hardware and 
software skills. ■ 
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Well, 

Your Micro’s Built 


... where do you 
grow from here? 


Lance Le vent ha/ teaches microcomputer systems design 
(among other things) and seems to have a real knack for 
getting down to the grass roots level when he writes about the 
little beasts. His article discusses microcomputer architecture 
(particularly the memory and I/O sections) and provides us 
with some good introductory material on the subject (an 
introduction to microprocessor architecture by a PhD .. . but 
not for PhDs). — John , 


M any novices to the 
computer field see a 
computer kit advertised for a 
few hundred dollars and 
think the kit will be all they 
need for whatever project 
they might imagine. However, 
they soon discover they can 
do almost nothing with the 
basic kit. They have no 
convenient way to enter data 
into the computer or get 
results from it, no way to 
attach peripherals or equip¬ 
ment, and no place to store 
data or programs* Of course, 
the company that supplied 
the kit will provide all the 
additional circuit boards the 
user needs, hut the user soon 
finds the cost of the com- 
puter kit was a small part of 
the cost of the total system. 
A device like the IMSA1 8080 
(shown in Photo 1) may look 
like everyone's idea of a 
computer, but it can't do 
very much without additional 



Dr. Lance LeventhaI 
Emulative Systems Co. 
138 So. Acacta Ave 
Solang Beach CA 92075 


internal circuitry and external 
equipment* 

But, you may ask, "! 
thought the microprocessor 
only cost StO or St5 and that 
it was a complete computer- 
omachip." Why does a work¬ 
ing system cost thousands of 
dollars? The answer is that 
the microprocessor Is not a 
complete computer, but only 
a section of one. Although 
the cost of the microproces¬ 
sor is small, the rest of the 
computer is still expensive 
(although it, too, is becoming 
cheaper). The situation is as if 
automobile engines had 
become free; automobiles 
would still be quite expensive 
because of the body, seats, 
controls, transmission, other 
equipment, and labor* A 
manufacturer of a micro¬ 
processor-based product 
remarked at a recent con¬ 
ference that "The single most 
expensive item in our product 


A Small Computer , the 
I MS AI 8080 (Courtesy of 
IMS Associates Inc.). 
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is the case. If we didn't make 
the case ourselves, we really 
couldn't make any profit." 

Newcomers to computers 
often don't understand that a 
computer is not just a single 
enormous device. In fact, a 
computer consists of several 
distinct sections which can 
vary greatly in complexity. 
Not only does the speed vary 
but so does the size of their 
memories, the number and 
speed of their input/output 
channels, the types of tasks 
which they are best suited to 
perform, and the number and 
type of devices (called periph¬ 
erals) and programs (called 
software) which are available 
with them. A total computer 
system is more than just an 
electronic brain, the brain 
must have a memory to store 
information, channels over 
which to transfer information 
to and from the outside 
world, and input/output 
devices which prepare data or 
record results. A computer 
without these features is like 
a person who can think but 
cannot remember and has no 
senses to provide data or 
muscles which the brain can 
direct. 


Computer Structure 

A computer consists of 
three basic sections: the con¬ 
trol section (often called the 
central processing unit or 
CPU), the memory section, 
and the input-output section. 
Fig. 1 shows the sections and 
the paths which connect 
them. The control section 
actually processes the data; it 
gets the instructions from 
memory, decodes and exe¬ 
cutes them, performs arith¬ 
metic and logical functions, 
transfers data to or from the 
memory and input/output 
devices, and provides timing 
and control signals. The 
memory section contains 
storage for instructions and 
data. The input/output sec¬ 
tion handles the communica¬ 
tions between the computer 
and the outside world. Signals 
of various types flow from 
one section to another along 


Fig. 1. Block Diagram of a 
Typical Computer. 



paths called buses. A micro¬ 
processor consists only of a 
CPU. Memory and input/ 
output circuitry must be 
added to make a working 
computer or microcomputer. 
A simple, cheap microcom¬ 
puter like the one shown in 
Photo 2 is possible only if the 
memory and input/output 
requirements are quite 
limited. This article will 
discuss the memory and 
input/output sections of com¬ 
puters; the next article in the 
series will discuss the CPU. 

Memory Section 

The memory section is the 
simplest section to describe. 
The memory consists of cells 
which have two stable states. 
We call one of these states 
"zero" and the other "one"; 
thus we can use each cell to 
represent a binary digit or bit. 
Since we usually want the 
CPU to handle more than one 


bit at a time, we organize the 
binary cells into groupings of 
fixed length. The smallest 
grouping is a byte which 
generally contains 8 bits. The 
basic grouping of bits which 
the control section can 
handle at one time is a word. 
Computer word lengths vary 
from 4 to 64 bits and are 
generally the bit lengths of 
the control section's internal 
structure and the computer's 
data paths. Note that, in the 
case of an 8 bit CPU like the 
Intel 8080 or Motorola 6800, 
a word and a byte have the 
same length. 

Word length is one mea¬ 
sure of the power of a com¬ 
puter. A computer with a 
longer word can do more 
work than one with a shorter 
word, even if both computers 
operate at the same speed. 
The word length determines 
the amount of work done 
during each cycle. Large 


computers have long words — 
32 bits (IBM 360), 36 bits 
(Univac 1110), or even 64 
bits (Control Data 6600). 
Minicomputers have shorter 
words — 12 bits (Digital 
PDP-8) or 16 bits (Digital 
PDP-11 or Data General 
Nova). Microcomputers have 
still shorter words — usually 8 
bits (Intel 8080, Motorola 
6800, and MOS Technology 
6502). 

Obviously, in order to use 
a particular grouping of bits 
in a memory, the CPU must 
have some way of identifying 
that grouping. The identifica¬ 
tion used to select a particu¬ 
lar byte or word is called an 
address . The address identi¬ 
fies the position of a byte or 
word, not its contents. 
Remember the difference 
between data and addresses! 
For example, byte #25 can 
contain any 8-bit number, 
not just the number 25. We 


Fig. 2. Memories with single 
bit words can be combined in 
parallel to form the longer 
words needed for computer 
memories. AH the 1 bit 
memories have the same 
CONTROL, ADDRESS, and 
ENABLE connections. The 
only difference is that the 
data line on each memory is 
connected to a different fine 
of the computer's data bus. 


CONTROL ADDRESS ENABLE 
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Address Length 

Memory Size 

(Bits) 

(Bytes) 

8 

256 

9 

512 

10 

IK 

11 

2K 

12 

4K 

13 

8K 

14 

16K 

15 

32K 

16 

64K 


Table l 

Memory Size vs. Address Length, 


often use parentheses to indi¬ 
cate "contents of" and avoid 
this confusion. Thus 1000 
means address #1000 and 
(1000) means the data which 
is in address #1000. 

Each byte or word of 
memory needs a separate 
address. The bit length of the 
addresses determines how 
many words of memory can 
be easily attached to a CPU. 
Each time we add a bit to 
the length of the address, we 
double the memory capacity. 
Table 1 shows the relation¬ 
ship between the bit length of 
the addresses and the memo¬ 
ry capacity for addresses 
between 8 and 16 bits long. 
Most small computers use 12 
or 16 bit addresses so that 
they can handle 4K or 64K 
bytes of memory (IK = 1024 
or approximately 1000). 
Note that the length of the 
addresses and the data is 
often not the same. Most 
microprocessors use 8 bit 
data words and 16 bit ad¬ 
dresses. This allows the user 
to attach a reasonable 
amount of memory to the 
processor, but causes diffi¬ 
culties in handling addresses. 

Both data and instructions 
are stored in the memory 
section of most computers. A 
computer which has data and 
instructions in the same form 
is called a Von Neumann 
machine after the mathemati¬ 
cian who first proposed this 
method of storing programs. 
How do we tell whether a 
number is data or an instruc¬ 
tion? The answer is that we 
can't tell. During an instruc¬ 
tion fetch cycle, the CPU 
takes whatever number it gets 
from the memory and places 
the number in the instruction 
register. During a data fetch 
cycle , the CPU places the 


number it gets in a data regis¬ 
ter. For instance, in the case 
of the Intel 8080 CPU, the 
binary number 00001001 
would be the instruction 
DAD B (double add with 
register B) if the CPU ob¬ 
tained it during an instruction 
fetch cycle and the number 9 
if the CPU obtained it during 
a data fetch cycle. But 
couldn't the CPU get con¬ 
fused and start executing the 
data? The answer is yes, if we 
don't direct the CPU to the 
right place in the memory. 
The programmer must ensure 
that the computer gets data 
and instructions in the cor¬ 
rect order. The computer will 
do whatever it is told to do, 
whether it makes any sense or 
not. 

The memory section con¬ 
tains other devices besides the 
memory itself. The address 
decoder uses the addresses to 
select particular memory 
locations. Other circuitry 
may provide control signals 
for the memories, allow the 
memory section and control 
section to communicate prop¬ 
erly, and ensure that the 
memory section retains its 
contents. We use standard 
integrated circuits or special 
controllers to preserve the 
contents of memories. We use 
other integrated circuits in 
the memory section as decod¬ 
ers, buffers, and latches. Thus 
the memory section of a 
small computer usually con¬ 
sists of several circuit boards, 
each containing a few thou¬ 
sand words of memory and 
some supporting circuitry. A 
small computer has room for 
these memory boards, each of 
which will typically cost one 
to two hundred dollars. 
Semiconductor Memories 

Virtually all hobby com¬ 


puters use semiconductor 
memory chips to store pro¬ 
grams and data. These chips 
provide large amounts of 
storage in a compact form at 
very low cost. Larger chips 
and other associated LSI 
dev ices prom ise to make 
semiconductor memories 
even cheaper in the future. 

Three major types of semi¬ 
conductor memories exist: 
ROMs (read-only memories), 
PROMs (programmable read¬ 
only memories), and RAMs 
(random-access read-write 
memories). ROMs have their 
contents determined at the 
factory as part of the manu¬ 
facturing process. A rather 
large masking charge (usually 
several hundred dollars) is 
involved; so ROMs are only 
economical when a large 
quantity with the same pat¬ 
tern is ordered. Thus most 
hobbyists will only use 
special-purpose ROMs which 
can be purchased without a 
masking charge. These ROMs 
include character generators 
for CRT displays and print¬ 
ers, various code converters 
(such as Selectric to ASCII), 
and tables such as sines or 
cosines. 

Hobbyists are far more 
likely to use the PROM, a 
read-only memory which can 
be programmed by the user 
under special conditions. 
PROMs can have their con¬ 
tents changed by means of 
specified high voltage pulses. 
A PROM has most of the 
advantages of a ROM — it is 
non-volatile so it does not 
lose its contents when the 
power is turned off, it cannot 
be accidentally changed by an 
erroneous user program or 
computer malfunction, and it 
can provide a rather large 


amount of storage on a single 
chip at low cost. PROMs are 
somewhat more expensive 
than ROMs but can be 
purchased in small quantities 
without a masking charge. 
Note that the PROM cannot 
be altered during ordinary 
computer operation. 

PROMs are available in 
many semiconductor technol¬ 
ogies; but hobbyists usually 
find the erasable MOS 
PROMs the cheapest and 
easiest to obtain. We often 
call such PROMs EPROMs or 
EROMs . The most popular 
PROM is the Intel 1702A 
which has 256 8-bit words. 
The 1702A is relatively slow 
(1 or 1.5 microsecond access 
time), but is cheap ($5 to 
$15) and available from many 
sources. Larger PROMs (512 
or 1024 8-bit words) and 
faster PROMs (access time 
around 500 nanoseconds) are 
available but cost much more 
than 1702As. The price of 
PROMs is continually drop¬ 
ping however; the larger and 
faster PROMs which now cost 
$30 to $50 each will proba¬ 
bly be in the $20 price range 
by next year. 

Hobbyists may choose to 
purchase, program, and erase 
their own PROMs. PROM 
programming circuits can be 
constructed or purchased in 
kit form. However, these 
circuits require high voltages 
which often must be main¬ 
tained to within a rather close 
tolerance, so most hobbyists 
will prefer to let PROM or 
hobby computer vendors 
program or erase and re¬ 
program their PROMs for a 
small extra charge. Most 
erasable PROMs (like the 
1702A) must be placed under 
an ultraviolet light source for 
about ten minutes to erase 
the contents. The entire 
PROM is erased; single bits or 
words cannot be corrected. 
Some new PROMs like the 
AMI S6834 (a 512x8 PROM 
designed for AM I/Motorola 
6800 systems) are more flexi¬ 
ble; single locations can be 
erased by means of a single 
high voltage input without 
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even removing the PROM 
from the circuit board. 

Many hobbyists will prefer 
to purchase preprogrammed 
PROMs, The ones now avail¬ 
able generally contain debug¬ 
ging packages and system 
monitors. However, sophisti¬ 
cated loaders, assemblers, 
compilers, and other pro¬ 
grams should be available in 
PROMs in the next few years. 
Larger PROMs at lower prices 
will make such PROM-based 
software economical. In fact, 
Microcomputer Technique 
now offers a PROM-based 
Intel 8080 assembler, and 
Microcomputer Associates 
offers a PROM-based MOS 
Technology 6502 assembler. 
PROM-based software is 
convenient since it doesn't 
have to be loaded into memo¬ 
ry each time it is used, and it 
can't be written into or acci¬ 
dentally changed. The PROM 
may simply be removed from 
the board or system if the 
memory space is needed for 
other purposes. 

Although PROMs are 
useful for software packages 
and for final versions of pro¬ 
grams, the basic memory in 
most hobby computers will 
be RAM. Random-access real¬ 
ly means that all locations 
can be reached in the same 
amount of time; in fact. 


ROMs and PROMs are 
random-access, although the 
term is usually reserved for 
read/write memories — shift 
registers and cassette tapes 
are examples of memories 
that are not random-access, 
RAMs are significantly more 
complex than ROMs or 
PROMs because of the need 
to both read and write data at 
the same voltage levels, RAM 
memory chips therefore con¬ 
tain fewer bits (4K bits is a 
large RAM, while PROMs are 
available commonly in sizes 
up to 8K and ROMs up to 
16K). However, single-chip 
RAMs with more bits are 
becoming available; in the last 
ten years, the largest single¬ 
chip RAM has increased In 
size from 256 bits to 16k bits 
while its cost has remained 
about the same. 

The standard RAM at the 
present time is the IK by 1 
2102-type device. Currently 
such RAMs sell for about $1 
to $2 each. Note that each 
2102 only has a 1-bit word; 
in order to form 1K 8-bit 
words, 8 2102s must be con¬ 
nected in parallel, with each 
RAM connected to a differ¬ 
ent bit of the data bus. (See 
Fig. 2 for an illustration of 
how we wire the memories.) 
Although the resulting word 
may be considered (and 


addressed) as a unit, each bit 
of the word actually resides 
in a separate 2102 memory. 
Several versions of the 2102 
are produced which vary in 
access time and power con¬ 
sumption, A memory with an 
access time of about 500 
nanoseconds is required to 
run an Intel 8080 or Motoro¬ 
la 6800 processor at full 
speed. 

Larger RAMs are available 
at higher cost. 4K RAMs are 
often used in the memory 
boards which can be pur¬ 
chased from many manu¬ 
facturers; they cost $20 in 
small quantities but much less 
in large quantities. Like the 
2102 IK RAMs, most 4K 
RAMs are organized into 1 
bit words; so they must be 
connected in parallel in order 
to be used as computer 
memories. MOst 4K RAMs 
are dynamic, i.e„ they lose 
their contents unless that 
information Is written back 
into them every once in a 
while. Such RAMs use capaci¬ 
tive memory cells which 
discharge after a certain 
amount of time, A typical 
dynamic RAM must have its 
contents restored (or re¬ 
freshed) every 2 milliseconds; 
memory boards will contain 
the circuitry to perform the 
refresh, which is accom¬ 


plished automatically so that 
the computer user is unaware 
of it (although it does slow 
the computer somewhat). 
Dynamic RAMs are cheaper, 
denser, and use less power 
than the so-called static 
RAMs which do not have to 
be refreshed. New LSI chips 
are becoming available to 
handle refresh; some proces¬ 
sors (such as the new Zilog 
device) even include on-chip 
refresh ci rcuitry. Future 
developments in RAMs will 
Include faster devices (MOS 
RAMs are now available with 
access times of 100 nano¬ 
seconds), larger devices {16K 
single-chip RAMs are now 
being tested), and devices 
with more convenient organi¬ 
zations (such as 8 or even 16 
bit words). 

All RAMs currently are 
volatile, i.e,, they lose their 
contents when power is 
removed. Thus programs or 
data have to be reloaded each 
time power is accidentally 
lost or the computer is turned 
off. Obviously, volatility is an 
inconvenient feature when a 
long program must be re¬ 
entered from a slow paper- 
tape reader or keyboard. A 
small battery can be used to 
provide backup power if 
needed, CMOS memories 


A Simple Microcomputer, the 
E and L Instruments Mini- 
Micro Designer (Courtesy of 
E and L Instruments Inc.). 
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often have a low-power stand¬ 
by mode whereby data can be 
reta ined with a very small 
power drain. However, such 
memories are rather expen¬ 
sive and are only available tn 
small sizes. While the develop¬ 
ment of a nonvolatile RAM 
is several years away, low- 
power RAMs which can 
Operate with small batteries 
(or smaller power supplies) 
will become more widely 
available in the near future. 
Semiconductor memory 
chips are a key part of hobby 
computers* PROMs can be 
used for final versions of pro¬ 
grams and for monitors and 
other standard software. 
RAMs are the basic for al¬ 
most all user memory. Lower 
prices, larger sizes, more con¬ 
venient organizations, and 
Le., 1 t 2, 4, or 8 bit, and 
lower power consumption 
wilt serve to make semicon¬ 
ductor memory chips even 
more useful in the future. 

Input/Output Section 

The input/output section 
of a computer is an interface 
between the computer and 
the outside world. The com¬ 
puter is a digital electronic 
device which has its own 
internal clock and uses cer¬ 
tain specified voltage levels to 
indicate binary zeroes or 
ones. Obviously few external 
devices operate in the same 
way as the computer. The 
input/output section must 
convert the input data sent 


from the outside world to a 
form the computer can 
understand and convert the 
output data sent by the 
computer to a form the out- 
side world can understand. 
This conversion may be a 
very complex task. Often the 
CPU will perform part of the 
conversion; some large com¬ 
puters have separate proces¬ 
sors which handle input/ 
output tasks. 

As with memory storage, 
the CPU handles input and 
output data in binary form. 
The CPU may handle a single 
bit at a time {serial input or 
output) or it may handle 
several bits at once {parallel 
input or output). Each sepa¬ 
rate grouping of input or 
output lines is called a port, 
which may have any bit 
length (although ports with 
the computer's word length 
are often the most conve¬ 
nient). Each port must have 
an identifying address so that 
the computer can direct data 
to or from it. The addresses 
may be determined by the 
same decoding system used 
for the memory section; this 
method is called memory- 
mapped input/output and 
means that the computer 
does not basically distinguish 
between memory locations 
and input/output ports. The 
addresses may, on the other 
hand, be determined by a 
completely separate decoding 
system; this method is called 
isolated input/output and 


means that the computer 
handles memory locations 
and input/output ports differ¬ 
ently. 

The input/output section 
will have to consider many 
characteristics of the trans¬ 
mitted signals in order to 
convert the signals into their 
proper input or output form. 
Among the characteristics 
which must be considered 
are: 

1) Signal level 

External devices, even when 
using two voltage levels to 
represent the two possible 
values of a bit, may use dif¬ 
ferent voltage levels than the 
computer. Most computers 
use TTL (Transistor-Transis¬ 
tor Logic) levels, i.e., 0 volts 
for a binary 0 and +5 volts 
for a binary 1. However, 
some terminals use 12 volt 
signals, and gas ionization 
displays require signals of 1 50 
volts or more in order to 
ionize the gas and provide 
visible light. The input/ 
output section must convert 
signals from one set of levels 
to another. 

2) Signal type 

Many external devices don’t 
use binary voltage levels. 
They may use current levels 
like a standard teletypewriter. 
They may use continuous 
(analog) signals of various 
types like a motor or ther¬ 
mometer. The input/output 
section must convert input 
data into the voltage levels 
which the computer under¬ 


An Analog I/O Board 
(Courtesy of Polymorphic 
Systems). 


stands and convert output 
data into the types of signals 
expected by external devices. 
The analog I/O board from 
Polymorphic Systems (shown 
in photo) contains latches 
(Intel 8212), decoding cir¬ 
cuitry, and the converters 
needed to interface between 
the digital computer and the 
analog world. 

3) Signal duration 

A computer works much 
more rapidly than most exter¬ 
nal devices or observers. It 
will send its output data only 
as a very brief pulse. The 
input/output section must 
hold or latch the computer's 
signals so that an output 
device will have time to 
respond to them. For exam* 
pie, we won't be able to see a 
light unless it is lit for a tenth 
of a second; however, unless 
the input/output section 
holds the output data, the 
computer will turn the light 
on only for a few micro¬ 
seconds. The input/output 
section also must latch input 
data so that the computer 
will be sure to see it even if 
the computer is performing 
other tasks at the time the 
data arrives. 

4) Signal timing 

The computer accepts inputs 
and produces outputs at 
times determined by its own 
clock. External devices, 
however, work at their own 
pace in a way that rarely 
coincides with the computer 


53 








The Teletype Model 33 ASH 
Date Terminal f a Standard 
Te/e type writer {Courtesy o f 
Tele type Co rpo ra tion). 


clock. Thus the input/output 
section must reconcile the 
tinning of the computer and 
the external devices. It must 
hold the signal from externa! 
devices and send them to the 
computer when the computer 
requests them; if must also 
hold signals from the com¬ 
puter and send them to the 
external devices at the proper 
time. 


The computer and external 
clocks are often very differ¬ 
ent. A typical computer, for 
instance, can transfer 
100,000 characters per sec¬ 
ond while a typical teletype¬ 
writer (see photo) can trans¬ 
fer just 10 characters per 
second. Note the tremendous 
range of speeds involved. A 
computer may have to handle 
data from a temperature 


sensor which provides a read¬ 
ing every five minutes, a tele¬ 
typewriter which operates at 
110 bits per second, and a 
floppy disk (see photo) which 
transfers 250,000 bits per 
second. 

5) Signal format 
External devices often pro¬ 
duce or require data in special 
formats. The external devices 


may expect data serially (i.e., 
one bit at a time). They may 
require or use special signals 
to indicate the start or end of 
a message. They may use 
special codes which reduce 
the probability of transmis¬ 
sion errors. The input/output 
section will have to convert 
data between the format used 
by the computer and the 
format used by the input or 
output devices. 

Clearly the input/output 
section of a computer can be 
quite complex. In simple 
cases, standard TTL latches 
hold input or output data; 
buffers and drivers ensure 
that the computer transfers 
signals correctly. Level trans¬ 
lators provide the correct 
voltage levels, while analog to 
digital (A to 0) and digital to 
analog (D to A) converters 
interface between analog 
devices and the digital com¬ 
puter. We often use special 
integrated circuits to format 
signals properly and resolve 
timing differences. A univer¬ 
sal asynchronous receiver/ 
transmitter (UART) performs 
serial/parallel conversions, 
provides proper formats and 
timing, and checks for various 
types of errors. Other devices 
that are often used include 
serial and parallel interfaces 
which we can program from 
the CPU to perform a variety 
of system functions. Thus the 
input/output section of a 


A Floppy Disk System 
(Courtesy of IMS Associates 
Inc.). 
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small computer will comist of 
several circuit boards, each 
containing devices specially 
designed for specific input/ 
output functions- The input/ 
output section wilt also con¬ 
tain the decoding mechanism 
required to identify particular 
ports from their addresses. 

A single I/O board can 
involve a variety of circuits. 
The Polymorphic Systems 
Video Interface Board 
{shown in photo) contains 
decoders, latches, buffers, 
counters, timing circuitry, 
keyboard connections, 
random-access memory to 
hold the characters displayed 
on the television screen, a 
read-only memory to gener¬ 
ate the character patterns, 
and other devices required by 
the keyboard and video dis¬ 
play. A typical backplane (or 
motherboard), such as in the 
Altair System shown in Photo 
7, will have room for several 
I/O boards, each of which 
will cost one to two hundred 
dollars. The CPU, which was 
once the most expensive part 
of the computer, is now the 
cheapest. The new challenge 


for LSI technology is to 
greatly reduce the cost of the 
memory and input/output 
sections of microcomputers. 

Connecting The Sections 

Obviously we must con¬ 
nect the various sections of 
the computer. Data buses 
transfer data to or from the 
memory or input/output 
sections. Address buses trans¬ 
fer addresses to the memory 
or i nput/output sections. 
Control buses transfer control 
information between the vari¬ 
ous sections. In small com¬ 
puters, one bus often serves 
several purposes, Le. p the bus 
is time shared or multiplexed . 
Then the CPU must use con¬ 
trol signals to indicate what is 
on the bus at a particular 
time. 

Two special types of con¬ 
nections deserve further 
comment. One is the inter* 
rupt t a signal that demands 
the immediate attention of 
the CPU. Interrupts inform 
the CPU of the occurrence of 
external events such as an 
alarm condition or a periph¬ 
eral which is ready to send or 
receive data. The CPU does 


not have to wait for the 
external events or check the 
state of external devices. 
Instead, the CPU can perform 
other tasks until it is inter¬ 
rupted and then resume those 
other tasks after servicing the 
interrupt. Interrupts are 
useful for inputs which occur 
irregularly at rates much 
slower than the normal oper¬ 
ating speed of the computer. 

Direct memory access is a 
method of transferring data 
between the memory and 
input/output sections of the 
computer without involving 
the processor at all. The CPU 
does not have to fetch and 
store the data or fetch and 
decode the instructions which 
would be required to transfer 
the data. Direct memory 
access (DMA} can thus handle 
data much faster and more 
directly than the normal 
input/output channels. DMA 
systems are used for devices 
like disks or CRT displays 
requiring a data rate compara¬ 
ble to or faster than the 
operating speed of the 
computer. 

Interrupts and DMA are 
very convenient for handling 


different types of input/ 
output. However, both meth¬ 
ods involve special circuitry 
which further increases the 
cost of the computer system. 
As with many other Items, 
the price of the basic com¬ 
puter may be lost in the price 
of that extra equipment 
which makes the computer 
system most useful and con¬ 
venient. * 
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SPECIFICATIONS: 


# 


8K SC-8 Specifications: 

Access Time: 

500 ns Max, (225 max 
on request) 

Current Req: 

Less than 200 ma per 
1024 words maximum 

Memory Chip: 

AMD 91LQ2 APC flow 
power IK x 1) 

Voltage Supply: 

+ 5 to -MO volts 

Battery Standby: 

1,5 to 2 Volt. 

Automatic power 
loss sensing circuit. 
Eliminates need for 
switches. 

Address Select: 

8 ea Spst. switches 
in a Dip 1C package 
(No longer any need 
for a soldering iron 
to change address.) 

+ 5 Voft regulated: 

A ea, 7305 regulators 
with Individual heat 
sinks to run cooler. 

Wait States: 

NONE* Your wait light 
will not burn because 
of a memory watt 
state. 


ALL ADDRESS. CONTROL, AND DATA 
OUT LINES FULLY BUFFERED 


Circuit Board 

Double sided, G10 glass epoxy board 
Plated through holes. 5 mil. tin minimum 
Solder reflow processed 
Solder mask on both sides of PC board 
Component [ay out silk screened on 
component side of PC board 
Gold plated edge contacts 
No jumper wires used 
Professional layout techniques used 


ALL ADDRESS, CONTROL, AND DATA OUT LINES 
FULLY BUFFERED 

• 

QUANTITY, DEALER, AND CLUB INQUIRIES INVITED 
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1C SOCKETS INCLUDED 

$295.00 Kit - $394,00 Assembled — $2.00 Shipping and handling 
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Computer Control 
of the World! 

... turning ac powered devices 

on and off 
with your computer 


Hey, / think this is one a lot 
of us have been waiting for! 
Just the thing for those of us 
who would like to be able to 
turn the world on and off 
with our home sy terns. Since 
the world seems to be run¬ 
ning on 120 V ac, Chris has 
come up with an interesting 
article telling us how to turn 
it on and off ... using an 
optoisolater . — John. 

Chris Bo wick 
Box 35482 
Georgia Tech 
Atlanta GA 30332 

O ptoelectronics is fast 
becoming an important 
area in the design of all types 
of computer control cir¬ 
cuitry. There are many dif¬ 
ferent types of optoelectronic 
devices and even more possi¬ 
ble uses for them. One of the 
more interesting devices in 
this class of electronics, 
which is becoming popular in 
computer interface applica¬ 
tions, is the Photon-Coupled 
Isolator, or Optoisolator. 
With this amazing device it is 
now possible to control high 
voltage high power circuitry 
with TTL voltage levels from 
your personal computer 
system. This is done without 
actual electrical connection 
between the two devices. 
Therefore the line voltages, 
and their associated noise 
components, are not allowed 
back into the logic. 

This article will be a short 
look at only one of the many 
General Electric optoisolators 
available today, the H74C1. I 
will first try to cover some 
very basic theory on the 
device and then throw a 
couple of experiments at you 
for some "hands on" experi¬ 
ence. 

Theory 

The H74C1 contains a 
gallium arsenide infrared 
emitting diode (IRED) and a 
light-activated silicon con¬ 
trolled rectifier (LASCR) in a 
16-pin dual in-line package. 
The I RED is nothing more 
than a light emitting diode 
(LED) which emits light in 
the infrared region. The 
optoisolator is specifically 


designed to work with the 
7400, 74H00, and 74S00 
series of logic gates to control 
120 or 240 V ac power 
devices. 

The I RED is a very inter¬ 
esting device in that its elec¬ 
trical characteristics are very 
similar to any run-of-the-mill 
silicon diode. One unique 
difference with the I RED, 
however, is its ability to emit 
infrared light when it is 
forward biased. This char¬ 
acteristic is utilized in the 
H74C1 by coupling the light 
through some transparent 
dielectric material to a 
LASCR (or photo SCR, as it 
is sometimes called). 

Since the photo SCR and 
almost all other silicon light 
detectors are nothing more 
than a photodiode junction 
(not to be confused with the 
LED) and an amplifier, our 


INCIDENT 

LIGHT 



Fig. 1. incident light on a 
reverse biased photodiode 
causes current flow. 


best bet for understanding 
the photo SCR could quite 
possibly be found in under¬ 
standing the photodiode. 
Does that seem logical? 

The photodiode is a 
reverse biased P-N junction 
device which allows current 
to flow when light of the 
proper wavelength and inten¬ 
sity is directed toward the 
P-N junction (see Fig. I). 1 
Here's how. In any good 
reverse biased semiconductor 
diode, a depletion region will 
be formed around the two 
P-N type materials. This 
depletion region is, of course, 
nothing more than an electric 
field inside the diode. If light 
is directed toward the P-N 
junction, the energy from the 
light causes hole-electron 
pairs to be created, which are 
swept across the junction by 
the electric field that the 
depletion region had set up in 
the first place. This causes 
current to flow in the exter- 


IREO LASCR 



Fig. 2. The I RED and LASCR 
integrated into one discrete 
unit R is an externally corh 
nected resistor. 


nal circuitry of the diode. 

The photo SCR works in a 
similar manner. It does, 
however, have one more 
terminal than a regular photo¬ 
diode. This terminal is called 
the gate. For simplicity's sake 
let's just say that the gate 
allows the circuit designer to 
vary the sensitivity of the 
SCR for each different appli¬ 
cation. The gate is normally 
connected to the cathode of 
the photo SCR through some 
value of resistance. The par¬ 
ticular value depends on the 
given design specifications. 

Now that we understand 
the basic operation of the 
I RED and the LASCR as 
separate entities, let's see 
what happens as the two are 
merged into one discrete unit 
When this is done (see Fig. 2), 
it becomes obvious even to 
the most casual observer that 
a truly amazing device has 
been generated! When the 
I RED is forward biased it 
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Fig. 3. Pin diagram for the 
H74C1. Pin 3 has no connec¬ 
tion. 
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Infrared Emitting Diode 

Power Dissipation 100 milliwatts 

Forward Current (Continuous) 60 milliamps 

Forward Current 1 ampere 

(Peak, 100 micro sec. 1% duty cycle) 

Reverse Voltage 6 volts 

Photo SCR 

Peak Forward Voltage 200 volts 

RMS Forward Current 300 milliamps 

Forward Current 

(Peak, 100 micro sec. 1% duty cycle) 

Surge Current 5 amperes 

Table 1. H74C1 specifications. 

emits light This light is are available from the General 
coupled through the trans- Electric Semiconductor 
parent dielectric material to Products Department in 
the P-N junction of the Syracuse, hfew York. Some of 
LASCR, causing it to conduct the more important specified- 
during each half cycle that it tions have been listed for 
is reverse biased. This pro- your convenience in Table 1, 
duces a current in the exter- and the pin diagram for the 
nal circuitry of the photo six pin DIP is shown in Fig. 3. 
SCR giving us complete As stated previously, the 
optical isolation between 120 optoisolator can be used as a 
V ac and the TTL voltages TTL interface to line voltage 
which turned the I RED on in operated devices. In Fig. 4, 
the first place. which is a very simple exam- 

"So how can I use it?" pie of this type of operation, 
you say. Well, why don't we it is apparent that a high logic 
take a look! input (+5) would not allow 

the I RED to conduct. Since 
Technical Information and the LASCR would not "See" 
Experiments any light, it would remain off 

All technical specifications and the 15 Watt bulb would 
for the H74C1 optoisolator therefore not be lit If, how- 

•SV 


LOGIC 

INPUT 


Fig. 4. A 15 Watt logic probe? 


•5 V 



Fig. 5. Choose any one of up to ten different loads using this 
setup. The LED display will indicate which load is on. Note 
that pins 3 through 7 and 9 through 11 of the 74145 are 
terminated in the same fashion as pins 1 and 2. 



ever, a low logic level were 
applied to the input, the 
I RED would conduct 
(because it is now forward 
biased), emitting infrared 
light and gating the LASCR 
on during its reverse biased 
cycles. The bulb would then 
light! Well what have we 
here? Could it be a 15 Watt 
logic indicator? Of course, 
the bulb will glow with only 
half the normal brightness 
due to the LASCR con¬ 
ducting during only half of 
each line voltage cycle. As 
you can see, the concept is 
really very simple. 

Another very simple exam¬ 
ple you might like to try is 
seen in Fig. 5. This circuit 
will accept BCD data and 
then select any one of ten 
different loads to be switched 
on (be sure that the load you 
use doesn't cause the current 
and power ratings of the SCR 
to be exceeded). The LED 
display is there merely to 
indicate which load has been 
selected. The function table 
and pin diagram for the 
74145 are seen in Fig. 6. It is 
obvious from the function 
table that for any given valid 
input, all of the 74145's out¬ 
puts are high except one. 
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FUNCTION TABLE 



Fig 6. Pin assignments and 
function table for the 74145. 


That one output corresponds 
to the BCD data you place at 
the inputs to the chip. For 
example, if the D, C, B and A 
inputs were 0, +5, 0 and 0 
volts respectively (corre¬ 
sponding to the number 4 in 
binary notation), then the 
outputs of the chip would 
have 0 volts at output 
number 4 and +5 volts at all 
other outputs. Therefore, 
with the H74C1 operating as 
described before, load 
number 4 would be "on" 
while all others would be 
"off." The LED display 
would, of course, show the 
number 4 in this case, indi¬ 
cating which load had been 
turned on. By changing the 
BCD data at the inputs to the 
74145, we can therefore 
select any one of the ten 
loads we wish to be turned 
on. 

Conclusion 

The optoisolator is a truly 
fascinating device; it's versa¬ 
tile, fun to work with, and, 
most important, inexpensive. 
The cost usually runs much 
less than $2.00 from most 
General Electric distributors, 
and this is a lot less than its 
interface counterpart (the 
solid state relay) which 
usually sells at several times 
this price. 

Hopefully, through read¬ 
ing this article, you have been 
introduced to something both 
interesting and useful to you 
and your home system. 1 have 
only scratched the surface 
concerning the usefulness of 
this device, but who knows, 
maybe I have opened a few 
doors. 

I would like to thank Ms. 
Maureen Brown and Mr. 
David Eversman for their 
help, suggestions, and criti¬ 
cisms in preparing this arti¬ 
cle. ■ 
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Dennis Brown 
President, Wave Mate 
1015 W. 190th St. 
Gardena CA 90248 


Wire Wrapping 

... Try it! 


Dennis Brown is the man 
responsible for the Jupiter if 
computer system by Wave 
Mate , and f since the system 
modules are built using wire- 
wrap construction , it would 
be safe to assume he is a 
strong advocate of wire-wrap. 
And, so he is. His article 
discusses the advantages and 
disadvantages of going the 
wire-wrap route and also 
introduces us to a universal 
wire-wrap hoard offered by 
Wave Mate. A layout diagram 
for the board is included for 
those who would prefer to 
make their own, — John. 


"Wire-wrap is a registered trade¬ 
mark of Gardner-Deover. 


Photos by Roger Young* 


T his is the first in a series 
of articles on the Wave 
Mate Jupiter 11 computer 
system. The purpose of this 
article is to lead you slowly 
through the wire-wrap* maze 
and give you a better under¬ 
standing of wire-wrapping. 
More than this, I hope to 
calm your fears about wire- 
wrapping and show you the 
advantages it offers. Perhaps 
you may even see the beauty 
in this jungle of wires. I'm 
also going to introduce you 
to, and point out the benefits 
of, a truly beautiful and 
universal wire-wrap card. 

What is Wire-Wrapping? 

Wire-wrapping is a solder¬ 
less technique, for assembling 
electronic circuits, in which a 
small wire is wrapped tightly 
around a post, usually square 



CPU module for the Jupiter II computer system built on Wave 
Mate's universal wire-wrap cards. 


in shape. Bending the wire 
around the sharp corner of 
the post crushes the oxide 
layer on both the wire and 
the post together, creating an 
oxide free, gas tight, metal- 
to-metal contact. The wire 
also stretches as it is wrapped 
over the post, causing the 
post to be slightly twisted 
and under constant pressure 
at the points of contact. The 
posts are normally gold 
plated to prevent oxidation, 
and the wire is silver plated 
copper for better conduc¬ 
tivity. 

As the contact ages, the 
silver atoms of the wire and 
the gold atoms of the post 
fuse, creating an extremely 
reliable contact. This connec¬ 
tion is immune to shock, 
vibration, time, humidity and 



■Wire^vtrap t*J 

Hole for wire 

Hale lot oosf 


Fig. 1. Detail of wire-wrap bit 



Fig. 2. Detail of wire biting 
into wire-wrap post. 



®i_ 


fe) (f) 

Fig, 3 * Troubleshooting bad 
wraps, (a) Overwrap caused 
by pressing too hard on the 
tool I This condition is impos¬ 
sible if a power tool with a 
back force spring is used, (b) 
Spiral wrap caused by uneven 
pressure on the tool, (c) Open 
wrap caused by no pressure 
on the tool, (d) Insufficient 
turns caused by not pushing 
the stripped end of the wire 
far enough into the tool, (e) 
Pigtail caused by using the 
incorrect tool size. For 30 
gauge wire use a tool speci¬ 
fied for 30-32 gauge, if) Cor¬ 
rect wrap , The post should 
have at feast one turn of 
insulation. 
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temperature changes, A wire 
may be removed and another 
wrapped on the same post 
with the same high quality 
connection as the first. 

How is Wire-Wrapping Done? 

There are many tools avail¬ 
able to make wire-wrapping 
easy, including hand and 
electric tools as well as air 
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Fig. 4. Detail showing pos¬ 
sible socket configurations of 
any one of four rows. (a) 
Eight 18-pin sockets. The 
sockets are the tab foe variety 
which needs no soldering or 
adhesives to be retained in 
the card. Other screw down 

or adhesive-mount types can 
be used, (b) Three 18-pin 

sockets and one 40-pin 

socket The 40-pin socket is 
made from two 20-pin strips 
which are held to the board 
by soldering to two isolated 
lands t (c) Two 18-pin sockets 
and two 22-pin sockets . id) 
Two 18-pin sockets and two 
24-pin sockets. The 24-pin 
socket is made from two 
12-pin strips which are held 
to the board by soldering to 
two isoia ted lands, (e) One 
24-pin socket and one 40-pin 
socket, or one 64-pin socket 



Wire-wrap side of CPU module. 


powered models. However, alt 
are basically the same, 
consisting of a hard steel 
shaft (called a bit) with one 
large bote in the center of the 
end for the post and a 
smaller hole near the edge for 
the wire (Fig. 1 h 

A wire with one inch of 
insulation stripped from each 
end is pushed into the small 
hole so that the insulation is 
slightly inside the tool. The 
tool containing the wire is 
placed over the wire-wrap 
post and turned by hand or 
power, with a slight down¬ 
ward pressure. The loose end 
of the wire should be held 
stationary, forcing the wire to 
come out of the tool and 
wrap around the post so that 
the corners of the post bite 
into the wire forming a gas 
tight connection (Fig. 2.) 
With a powered tool, the bit 
turns at high speed and is 
surrounded by a stationary 
sleeve to avoid damage to 
nearby wires. 

For most electronic 
projects, the wire-wrapping 
posts should be 0.025 square 
and 0.625 inch long. The wire 
should be 30 gauge Kynar 
insulated solid copper wire, 
silver plated, and stripped one 
inch at each end. The wire- 
wrapped bit should be rated 
for 30-32 gauge wire. If these 
specifications are used, the 
bit will wrap about one turn 
of insulation and seven turns 
of wire on the post, 

Wi re-wrapping is easy, 
even if you have never done it 
before. After a few minutes 
of practice, you should get a 
good consistent wrap every 
time. Vttien wiring on the 
second level of a post, be sure 
to leave space between the 
top of the first wrap and the 
start of the second wrap. If 
you are having trouble getting 
consistent wraps, refer to Fig. 
3 for help. 

In contrast to other types 
of construction, wire-wrap 
offers many advantages and 
few disadvantages. Compared 
to soldered point-to-point 
wiring, wire-wrap wins hands 
down. Wire-wrap connections 


are much easier to remove 
and many times more reli¬ 
able. 

Printed circuit cards are 
the closest competitor to 
wire-wrap. For high volume 
applications, PC cards are 
more economical to produce. 
A single sided PC card has the 
most rugged construction, 
but few electronic projects 
are simple enough for one 
and most usually require the 
use of two or more layers of 
printed circuitry. If a multi¬ 
layered PC card is acciden¬ 
tally flexed the connections 
can be damaged. The etched 
layers will be pulled away 
from the plated-through-holes 
that are required to inter¬ 
connect them, A wire-wrap 
card, made with a single sided 
PC card, may be flexed 
vigorously without damage. 

Wire-wrapping forces you 
to use 1C sockets, which 
make diagnosing and repair¬ 
ing your project a snap. You 
can damage integrated cir¬ 
cuits by soldering them 
directly to a PC card; diagno¬ 
sis and repairs then become 
extremely difficult and time 
consuming. 

Wire-wrapping allows inte- 



Fig. 5. The ground clip slides 
over the wire-wrap post. The 
leg is then soldered directly 
to the ground piano. The PC 
card has an etched c ha ranee 
around each wire-wrap post 
to prevent accidental shorting 
of signal leads. 


grated circuit packages to be 
spaced much closer together 
than PC cards. Therefore, 
interconnections are much 
shorter, resulting in cleaner 
wave forms and reducing 
noise in the system. Since all 
the interconnections are 
wired, a ground plane can be 
etched on the card to elimi¬ 
nate noise and crosstalk, 
further increasing system 
reliability. 

The most important 
advantage of using wire-wrap 
is the ease and speed with 
which you can go from idea 
to finished project. Wire-wrap 
also enables you to change 
and upgrade your circuits 
with ease. Often you can go 
from start to finish of a 
project in a single day. 

All of these sound like 
great advantages that every¬ 
one can benefit from, so why 
isn't everyone selling wire- 
wrapped computers? The 
answer is twofold. First, the 
cost of a wire-wrap card is 
higher than an etched PC card 
because each 1C must be 
socketed and wiring a board 
takes longer than wave 
soldering. Second, all of these 
advantages are theoretical in 
nature. Most designs using 
wire-wrap cards fall short of 
the ideal for one or more 
reasons. Therefore, it is 
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vQiS Sggore 

Fig. 6. Detail of bus bar used 
for power distribution. The 
bar Is made from 0.025 thick 
half bard brass, with gold or 
tin plated leads. 
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Fig. 7. Maximum possible component layout for universal 
wire-wrap module: (a) RowD +12 Vbusbar, (b) Row D+5 V 
bus bar. (c) Row D+5 V high frequency bypass capacitor (0.1 
uF). (d) Row D +12 V high frequency bypass capacitor (0.1 
uF). (e) Row D +12 V low frequency filter capacitor (15 uF). 
(f) Row D +5 V low frequency filter capacitor (15 uF). (g) 
Row D -5 V high frequency bypass capacitor (0.1 uF). (h) 
Row D -12 V high frequency bypass capacitor (0.1 uF). (i) 
Row D -5 V bus bar. (/) Row D -12 V busbar, (k) Row D-12 
V low frequency filter capacitor (15 uF). (!) Row D-5 V low 
frequency filter capacitor (15 uF). (m) +12 V reverse voltage 
prevention diode (1N4001). (n) +5 V reverse voltage preven¬ 
tion diode (1N4001). (o) -12 V reverse voltage prevention 
diode (1N4001). (p) -5 V reverse voltage prevention diode 
(1N4001). (q) +12 V power regulator (7812). (r) +5 V power 
regulator (7805). (s) -12 V power regulator (7912). (t) -5 V 
power regulator (7905). (u) +12 V input filter capacitor (1 uF, 
35 V tantalum), (v) +5 V input filter capacitor (1 uF, 35 V 
tantalum). (w) -12 V input filter capacitor (1 uF, 35 V 
tantalum), (x) -5 V input filter capacitor (1 uF, 35 V 
tantalum), (y) 72 pin bus connector (Berg R/A hdrshld2x36 
30AU). (z) 50pin I/O header (3M $34963005). 


important, if you are seri¬ 
ously considering building or 
buying a wire-wrap project, 
to examine closely some of 
the features of the wire-wrap 
card that can make it a dream 
machine or a nightmare. 

What Features Should a 
Wire-Wrap Card Have? 

To take advantage of all 
the new large scale integra¬ 
tion (LSI) chips in your 
computer system you will 
need cards that can hold a 
wide variety of socket sizes: 


14 to 18 pins on 0.3 inch 
centers, 22 pins on 0.4 inch 
centers and 24 to 64 pins on 
0.6 inch centers. To power 
these new chips, the cards 
must have provisions for 
distributing up to four volt¬ 
ages, usually ±5 and ±12 V. 
Sometimes other voltages are 
necessary, including -9, -3 and 
+26 V. 

The cards should have a 
ground plane; every IC socket 
pin should be capable of 
connecting directly to the 
ground plane without using a 


wire-wrap wire. All voltages 
should have provisions for 
high frequency bypass capaci¬ 
tors every few packages. If 
on-card voltage regulation is 
used, a large heat sink should 
be provided. 

The cards should be large 
enough to hold a CPU, a 
memory or an I/O controller 
but small enough to ensure 
the modularity of the system. 
There should be room for 
many I/O connection pins 
and bus connections. 

The Wave Mate Universal 
Wire-Wrap Card 

Over the past few years 
Wave Mate has succeeded in 
making a universal wire-wrap 
card which meets all of the 
above specifications. We now 
manufacture all of our plug-in 
modules using these cards. 

Every Wave Mate plug-in 
module uses the same printed 
circuit card. However, each 
module contains a unique 
combination of integrated 
circuits and other compo¬ 
nents. The standard card is 
designed to accommodate the 
maximum number of 
components required to 
implement any function. 
Thus, it is unlikely that any 
module would require the 
board to be completely filled 
with components. 

The printed circuit board 
is designed to accommodate 
four rows of sockets. If the 
sockets contain up to 18 pins, 
they are mounted vertically, 
providing capacity for 8 
sockets per row for a 
maximum of thirty-two 
18-pin sockets per board. See 
Fig. 4(a). (22-, 24- or 40-pin 
sockets are mounted horizon¬ 
tally.) Each 24-pin socket 
displaces three 18-pin sockets 
in a row; a row may contain 
two 24-pin and two 18-pin 
sockets or one 24-pin and five 
18-pin sockets. See Fig. 4(d), 
A 40-pin socket displaces five 
18-pin sockets. See Fig. 4(b). 

Each socket location is 
designated by a row letter 
(A-D) and a column number 
( 1 - 8 ). 

All integrated circuits used 
on the card are plugged into 


sockets. The sockets perform 
the functions of both holding 
the ICs and providing a wire- 
wrap post for each pin of an 
IC. Discrete components are 
also plugged directly into 
wire-wrap sockets, making 
layout extremely versatile. 

Except for the edges, the 
entire etched surface of the 
card is a ground plane with 
etched clearance around each 
post (Fig. 5). All voltages are 
bussed along the edges of the 
card. The printed circuit card 
is capable of providing four 
different voltages to each 
socket mounted on the card. 
Each voltage is transmitted to 
the sockets by a power bus 
that spans each row. See Fig. 
6. The power bus for a 
voltage is only installed on a 
row if that voltage is required 
by an IC on that row. 

A set of 1 uF bypass 
capacitors filter the input to 
each of the regulators. Up to 
three 15 uF tantalum low 
frequency bypass capacitors 
are provided for each voltage 
used on the card. Two 0.1 uF 
high frequency bypass capac¬ 
itors are used at the end of 
each bus bar. A reverse- 
polarity-prevention diode is 
added for each voltage on the 
card. 

The card may connect to 
the system bus through a 
72-pin connector. Its gold pin 
type contacts provide a 
higher reliability connection 
than a PC edge connector. Up 
to 60 pins of flat cable I/O 
connectors can be placed at 
the top of the card. A card 
ejector can be installed at the 
top of the card for easy 
removal from a card cage. 
Fig. 7 is an illustration of the 
universal wire-wrap board. 

The Wrap-up 

The advantages and dis¬ 
advantages of both wire¬ 
wrapping and printed circuits 
have been shown along with 
an explanation of the wire¬ 
wrapping process. From this 
you can see that wire-wrap¬ 
ping, as a viable method of 
producing high reliability 
equipment, offers flexibility 
and ease of construction. 
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The universal wire-wrap 
card presented here over¬ 
comes the problems associ¬ 
ated with most other wire- 
wrap cards. It enables you to 
realize the full range of 
advantages available with 
wire* wrap. 

Future issues of Kilobaud 
and other magazines will be 
offering many construction 
articles, some for PC cards 
and others for breadboard- 
type construction. The 
universal card described here 
can be used conveniently 
with many such projects. The 
universal wire*wrap module is 
available (either in kit form 
or assembled), along with a 
complete line of wire-wrap 
tools and accessories, from 
Wave Mate, 1015 W. 190th 
St, Gardena CA 90248. 

Next month we'll begin a 
discussion of the Wave Mate 
Jupiter II computer system, 
which is built using the 
wire-wrap cards presented 
here. ■ 


Fig. 8 . Full size layout for the 
universal wire-wrap PC card. The 
black lines are etched away, the 
white areas are copper. Two oz. 
copper plated glass perforated 
board may be used by the more 
adventurous hobbyist who wishes 
to make his own. All the parts and 
designs shown are copyrighted and 
may not be manufactured for sale 
or distribution. 




from page JO 

thing. 1 know nothing about hard¬ 
ware! 

I read with interest Wayne Green’s 
editorial reprinted in PCCNewspaper. 
As a systems analyst in the U.S. Air 
Force and with a software back¬ 
ground. including a degree in com¬ 
puter science, I know the value of 
having ready-to-use software. / hate to 
reinvent the wheel! every time I want 
to do something new in the way of 


software programs. Hope your sug¬ 
gestions works out. 

Ronald G. Martin 
Omaha NE 68123 


Books on Basics 


Certainly you should start your 
new mag for the beginner, but you 
must prepare for the time when a 
great number of the readers are more 
advanced. All articles of a funda¬ 
mental nature should be stated for 
eventual inclusion in books. Also, I 
really do hope we can get a little math 
into Kilobaud. Computer approxima¬ 
tions are very important but cannot 


be understood at al! without a little 
math. 

Webb Simmons 
San Diego CA 92111 


You've brought up some good points, 
Webb. There are going to be new¬ 
comers getting into personal com* 
puters all the time, either as users or 
hobbyists, hopefully, in large num¬ 
bers. Kilobaud will have a wide variety 
of fundamental material (so we won V 
be repeating ourselves) and, at the 
same time, well provide interesting 
and provocative materia / for the non- 
beginnerI With regard to books . .. 
you hit it right on the head. We're 
going to be putting out some dandies. 


And as far as the math is concerned 
... again , you're right in there. A 
“little" math in Kilobaud should be 
just fine. White most of Kilobaud's 
readers can use simple high school 
algebra and trig, most of them proba¬ 
bly don’t want to. They’re going to 
prefer practical circuits or practical 
approaches to a subject. - John. 


Readers’ Service 


Glad to see that you will be going 
through with another computer- 
related publication. As the title shows, 

continued on page 90 
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Dick Wilcox has come up with a machine-independent discussion on the design of a "home 

brew" OPERATING SYSTEM. Dick recently completed the hardware and software 

development of a hobbyist 16-bit microprocessor board, which plugs into the Altair bus (would 

you believe?) and is complete with a sophisticated BASIC and Operating System. He has some Dick Wilcox 

very good ideas to share with those of us interested in developing our own operating systems. 1342 Mauna Loa Rd 

Well be hearing a lot from Dick. After getting the "big picture " in this first article, well find Tustin CA 92680 

the details on developing the individual modules in future articles. (And, / would suspect well 

also be seeing a future article on that 16-bit machine.) - John. 


The 


Hobbyist’s Operating System 


... Part 1: Introduction and Master Plan 


OPERATING SYSTEM: A program, or collection of routines, 
whose primary purpose is to assist in the running and monitoring 
of other programs. An operating system usually doesn't perform 
the desired specific task (which will be accomplished by the 
program being executed), but rather performs sub-tasks which 
enable the program to operate more efficiently. The main 
program in an operating system (the one that's running the 
show) has been referred to by a variety of names, such as 
monitor, executive and supervisor. In general, all terms mean the 
same thing and are sometimes used interchangably, although 
there are the purists who differentiate between them by the 
magnitude of functions which they perform. In this instance the 
term "operating system" usually refers to the larger and more 
flexible program which truly performs the task of monitoring 
the actual running of the user program, as well as the loading of 
it. MONITOR would therefore seem to be a good choice when 
referring to the operating systems main, or control program. 


T here are two main 
thoughts that I try to 
keep in mind whenever 1 
design a new function into a 
system, or especially when I 
sit down to initially rough 
out a new system approach 
from scratch. First, the main 
task that is given to an oper¬ 
ating system of any worth is 
to give a good, but easily 
u n d e r s t a ndabl e, command 
language to the person using 
the computer. 

Consider, for instance, the 
following two commands: 

R DO,CMPLR.1530 

*DSK:PROG.LST/L.PROC.RIN-DSK:PR0G.SRC 

COMPILE PROG WITH LISTIKC 

Both command sequences 
will get the job of compiling 
the program and creating a 


list file but it is quite obvious 
which one will cause fewer 
premature gray hairs. Under¬ 
standable commands to your 
computer certainly may not 
be the highest priority on 
your list if you are a high 
school student trying to 
impress the girl next door, 
but for the hobbyist who is 
designing a system for his 
wife to use, simplified lan¬ 
guage can be a real boon. It 
just might even help justify 
an additional 16K of memory 
instead of that new set of 
cookware which, as any 
devoted computer hobbyist 
will attest, has very little 
socially redeeming signifi¬ 
cance. The second command 
sequence shown is an ideal 
that probably will not be 
obtainable, for now, in the 


average microprocessor sys¬ 
tem due to the large amount 
of code required to process 
this "free-form" style. In 
actual practice, we shall prob¬ 
ably end up with a command 
language which is somewhere 
between the above. 

The second point I con¬ 
sider is the assistance that the 
operating system gives the 
programmer in the develop¬ 
ment and debugging of new 
programs. The ease of editing 
and saving source files, assem¬ 
bly or compilation of these 
files, and the eventual debug¬ 
ging of the object program 
can sometimes save several 
times over the effort of doing 
the same tasks on a limited 
system. The amount of effort 
expended in making the 
operating system a powerful 
tool should be proportional 
to the expected use of the 
system for new program crea¬ 
tion and test. A system which 
is eventually slated to be used 
mostly for production runs 
will not justify using re¬ 
sources for program develop¬ 
ment. On the other hand, a 
system which will spend most 
of its time in the hospital 
recovering from programming 
blunders should have as many 
gimmicks as possible to assist 
the doctor (you). A speedy 


recovery makes for a ready 
patient upon which you can 
test your next diabolical new 
coding. The system which I 
am proposing here can even¬ 
tually help you go from 
editing to assembly to test 
and results in a couple of 
minutes. 

The operating system 
presented here, and the basic 
ideas behind the functions it 
will perform, is of a magni¬ 
tude somewhere between the 
small monitors presently 
available on the hobbyist 
market and the large systems 
that run on the godlike com¬ 
puters in commercial opera¬ 
tions. In its fully expanded 
form it will provide you with 
an extremely flexible com¬ 
mand language including the 
ability to create your own 
commands without regenerat¬ 
ing the system itself. It will 
be floppy-disk based although 
it will run without a disk in a 
limited form. It will contain 
generalized I/O facilities 
which means you will not 
have to rewrite your pro¬ 
grams each time you add a 
new piece of gear to your 
computer. All data will be 
handled in the form of named 
files on disk or other storage 
media and will be processed 
through the operating system 
routines. Multi-user time 
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sharing in a limited environ- 
ment will be discussed for 
those who wish to delve into 
this frustrating field. These 
are the main functions of any 
good system but by no means 
should be considered either 
necessities or restrictions. 

One point I would like to 
make at this time is that 
although the general ideas 
presented here are used in 
many large-scale systems, 
they do lend themselves 
readily to the microcomputer 
field within the constraints of 
limited resources. The fully 
expanded operating system 
which I am describing has 
been implemented on at least 
three different makes of com¬ 
puters in some form or an¬ 
other. I am currently imple¬ 
menting it on a microcom¬ 
puter system, and I project 
that the totally resident 
portion of the monitor will 
take up about 12K bytes of 
memory. This article is not 
intended to be a theoretical 
dissertation on large system 
practices. It is to be treated as 
an introduction to the tech¬ 
niques that make flexibility 
in operating system design for 
microcomputers feasible — 
well within the grasp of the 
hobbyist's abilities. In writing 
about something as technical 
as software design, it is 
almost impossible to remain 
generalized enough at a low- 
key level and still convey 
sufficient information to be 
useful for design. Thus, I will 
attempt to first give a broad 
overview of each new concept 
introduced and then expand 
upon that concept at a tech¬ 
nical level in enough detail to 
give the interested reader a 
solid basis for design. 

Obviously there are trade¬ 
offs to be considered when 
designing your own system. 
Defining what your system is 
to do, and to what depth, is 
the first step in the process. 
Do not overlook the fact that 
an operating system is prob¬ 
ably the most flexible and 
dynamic piece of software 
you may ever write, so be 
sure to keep in mind the areas 
that you may want to add to 


later on as your system pro¬ 
gresses. A little bit of plan¬ 
ning at this stage will result in 
many saved hours of rewrite 
later on. Start off small, but 
keep big ideas land ideals) 
tucked away for ready refer¬ 
ence in the coding of your 
system. 

Shared Routines 

Any operating system 
worth its weight in salt must 
perform certain functions 
during the process of loading 
and running the problem 
programs. These functions 
will include, at minimum, 
interaction with the opera¬ 
tor's terminal, I/O processes 
to read and write the program 
storage device, and some 
minimum conversion routines 
for decimal- or hexadecimal- 
to-binary formats. Since these 
routines are necessary for 
proper operation of the 
operating system, why not 
make provisions for them to 
also be accessible to the pro¬ 
gram that is to be run? You 
don't make your friends bring 
along their own dishes when 
they come for a visit, do you? 
It makes as little sense to 
force each program to bring 
along its own I/O and conver¬ 
sion routines when these 
same routines are sitting idle 
in the resident monitor. 

Now we are faced with the 
problem of how to efficiently 
utilize these routines. Two 
main factors must be con¬ 
sidered here. The use (access) 
of these routines should be 
kept simple in order to dis¬ 
courage the programmer from 
generating them in his own 
program. An I/O call which 
takes a lot of thinking just to 
get a character printed on a 
terminal is defeating its own 
main purpose: to make the 
programmers job an absolute 
joy (well ... at least maybe 
not so formidable). The use 
of these routines must also be 
implemented in such a way as 
not to consume a lot of 
memory space or execution 
time — an overhead that 
cannot be tolerated in any 
system. 

It should be obvious that 


in order to use these monitor 
routines the program must 
either know exactly where 
they are or else be able to 
reach them through a general 
monitor call by passing along 
a code to indicate the specific 
routine that is desired. The 
general pros and cons to both 
methods will be discussed 
briefly. The first method, 
that of knowing the exact 
location of each routine, is 
the fastest in terms of execu¬ 
tion speed since there is no 
wasted effort by the monitor 
in decoding a specific code 
and then executing the rou¬ 
tine. The major drawback 
here is that, each time the 
monitor is altered and the 
routines change position in 
memory, all the calling pro¬ 
grams must be reassembled to 
reflect the new routine 
addresses. This can be circum¬ 
vented by using a table of 
calling sequences to the rou¬ 
tines, where the table never 
changes position in memory. 
This method places con¬ 
straints on the monitor design 
and also is not easily imple¬ 
mented in some microproces¬ 
sors. The second method has 
the distinct advantage that 
once the routines are assigned 
specific codes or numbers, 
they can then be called by 
these numbers which will 
never change, even though 
the monitor may go through 
several gyrations during its 
lifespan. The main disadvan¬ 
tage with this scheme lies in 
the fact that each time a 
routine is called there is an 
extra penalty which must be 
paid in execution speed 
because the monitor itself 
must decode the assigned 
routine number and then 
transfer control to that rou¬ 
tine. 

Another advantage to this 
second method is sometimes 
overlooked because of its 
subtle implications. Most of 
the routines which will be 
implemented as shareable 
units will require one or more 
arguments to be passed to 
them for use in the specific 
execution of the routine 
itself. These arguments are 


variables such as device names 
for I/O functions, data to be 
read or written, numbers to 
be converted, or addresses of 
data in memory to be acted 
upon. As these routines in the 
monitor become more sophis¬ 
ticated, the need to evaluate 
and preprocess these argu¬ 
ments into a suitable form 
rapidly increases. If the 
arguments follow a pre¬ 
defined format and the pre- 
process function is the same 
for all the routines to be 
called, this action can be 
accomplished by the general 
monitor call just prior to 
transferring control to the 
desired routine. In the operat¬ 
ing system which I have 
developed, I have chosen to 
implement the second meth¬ 
od. Future articles will 
expand upon the various 
methods which may be 
employed to implement this 
coding scheme in the more 
common microprocessor 
systems of today. 

Major System Units 

In the above section I 
presented the idea of incor¬ 
porating the ability for user 
programs to call some of the 
functions which were inher¬ 
ent in the operating system 
monitor because the monitor 
needed these routines in 
order to perform its own 
chores of loading and running 
programs. In a more flexible 
system, we can expand on 
this idea and include routines 
in the monitor which, though 
the monitor doesn't use 
them, are commonly used by 
user programs. If the calling 
structure is defined properly 
at the onset, all that is 
required to add a new routine 
to the system is to assign it 
the next available code 
number and then add it to 
the monitor program. Of 
course, there are tradeoffs to 
be considered here which 
exist in any generalized appli¬ 
cation. The more nifty little 
routines that we include in 
our monitor, the easier it is to 
sit down and write a new 
program to run under that 
system because much of the 
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(decimal, octal, or hexadeci¬ 
mal) 


USER 

PROCRAM 



Fig. 1. Expanded operating system block diagram. 


work is already done for us. 
However, keep in mind that 
these little devils subtly 
gobble up valuable memory 
resources whether they are 
actually put to use by each 
program or not An operating 
system that does all kinds of 
great things but takes up 31K 
bytes out of a 32K byte 
computer might be as useful 
as a gold-plated garbage can. 

Following is a list of the 
major system components 
which I have found to be of 
sufficient value to justify 
their existence in an operat¬ 
ing system such as we would 
like to develop. (Refer also to 
Fig. 1.) This list is neither 
complete or necessary but 
merely is a guideline which 


you can build upon or set an 
eventual goal for your sys¬ 
tem. Each item in the list 
should be reviewed with care 
and evaluated as to its par¬ 
ticular worth for you. The 
goal in this evaluation need 
not be whether to include the 
major unit, but rather the 
degree to which you will 
implement it and the pro¬ 
posed subunits or options it 
will support. Remember that 
vanilla and chocolate ice 
cream both sell equally well 
because no two people are 
alike. 

1. Terminal service routines 
for communicating with the 
variety of available video dis¬ 
plays and hard-copy devices 


2. Logical I/O routines to 
relieve the programmer of 
communicating with peri¬ 
pheral devices on a physical 
transfer level 

3. Command level processor 
to evaluate operator input 
commands and perform 
specific system functions or 
execute a user program 

4. File-structured disk 
management system for stor¬ 
age of programs, source files, 
and data files on floppy or 
hard-surfaced disks 

5. Numeric conversion rou¬ 
tines to convert ASCII 
numeric input to packed 
binary format and vice versa 



6. Memory management 
system for allocating and 
keeping track of user requests 
for main memory areas and 
program usage 

7. Monitor subroutine dis¬ 
patching system for linking 
monitor routines to the run¬ 
ning program for execution 
(discussed previously) 

We will briefly describe 
here each major unit as to its 
general function and the 
tradeoffs involved in imple¬ 
menting it in various stages 
during operating system 
development. Future articles 
will treat each item in greater 
detail giving the reader the 
necessary information to 
evaluate its implementation 
into his or her system. 

Terminal Service Routines 

With the possible excep¬ 
tion of a few fanatical die- 
hards, nobody likes to con¬ 
trol his system by flipping a 
few toggle switches up and 
down in some ancient ritualis¬ 
tic rhythm. The big boys use 
a terminal to control all 
functions performed by the 
computer and if we intend to 
play the big boys' games we 
should strive to play in full 
dress uniform. The operating 
system should accept com¬ 
mands from the operator via 
one or more terminal devices. 
Processing input from any 
terminal requires some special 
considerations when com¬ 
pared to input from other 
peripheral devices such as 
paper tape or cassette readers. 
Special editing features, such 
as character rubout and full 
line erase, must be incorpo¬ 
rated to make the operators 
life more bearable. Most 
terminals require that the 
input character be trans¬ 
mitted to the corresponding 
output port (echoing). This 
allows you to view what you 
have typed in and, if you 
type like I do, this is an 
absolute must! The variety of 
terminals available to the 
hobbyist also poses some 
other interesting problems. 


MONITOR 

INTERFACE 


COM MAN 0 
PROCESSOR 



VIDEO UNIT cl 


VIDEO UNIT *2 


Fig. 2. Typical terminal service system. 


70 





: ■ft; ;b*ft: «■:ft: ■ >■ ■ ft: ft ■ ft x: cftftft ■ ftft ft: ft -ft*:,; 





m vwm mm m 


m 


TERMS: Add 5QC handling to orders under 
$10. Cal res add tax. No COD, to place 
BankAroericard® or Mastercharge^ orders, 
call (415) 562-0636 ( 24 hours. 


If you want to see the latest in interesting goodies for 
computer hobbyists, ask for our current flyer. It has 
AUair/IUSAI etc compatible peripheraIs; some of the newest 
octal parts, a complete line of TTI,, CMOS * and Low Power 
Schottky ICs; power supplies; connectors; enclosures; and 
all the capacitors & resistors you could ever want, as well 
as a full line of Vector products^--SKND FOR OUR FLYER! f 


m 


MENTION IHE NAME OF | 
THIS MAGAZINE ON 
YOUR ORDER AND YOU f 
CAN DEDUCT SI OF | 
THE TOTAL! 

NEW! EncLosures From VECTOR? 




I 




Deluxe cases that look beautiful---no screws or 
fasteners mar the good looks from the outside. 
Interior slots hold card guides, connectors. 

T;i etc. (not included with enclosure) 

All enclosures available in either 
dart blue or black with white 
front panel. Order froa the 
following— 

JVP5-17-17U; 5,51" II, 17.Sfi''W, 

|i:17.1 Hf P, V9.25 


*\ T7-17-I7U: 7.26" H, 17.SS" 
17*1" D, $34.00 


m 


*VF9-l7-2lU: 9,01" H* 17.£S"W* 
:^2l*6"D P This is exactly the 
ft: same size as the IttiAJ BOBO nicro- 


5S> 


computer. 


|96.SQ 


please include enough 


:£i:All units shipped unassembled^ 
i :j£ for postage (excess refunded). 

aecimvm 

ft:-: ■; v: : ftTft:-:*:;: ■:■:■ *■: • :■:■>;■;■ ftft; -.ft ft;ft; 

* I ff^» : >™ : 

mini 


Submini "D", 

Connectors! 



§ 


This by & senary hoard has 
no frills, just storage. De¬ 
signed for compatibility with 
JOLT -iystecis, this board is 
also ideal for other micro¬ 
computers using bi-direction¬ 
al buss systems. Sane sire 
as JOLT memory card, plus lo- 
power operation (1.3Aianx) to 
keep you on good terms with 
your power supply. 

If you don't need the onboard 
regulation or address / data 
buffers of our "Bigger Bro¬ 
ther" 4K board, then this is 
the way to go. 

Sockets Included for all ICs» 


x ft: ; ft: ft ft ft:;:: ft ; ; « ft. ; ::; ; ft ; : ; ■ ft-: 


in kit form 

$ 99.95 


MALE 

MALE 


WITH HOOD S3 
CONNECTOR $3. 


D-C-t • • < 4 t tj 

—[—FEMALE —I— 


HERE'S YOUR CHANCC TO BUY SOME TCP DUALI¬ 
TY SOLPERTAIL SOCKETS AT THE RIGHT PRICE- 
lb PIN...10/0^■15 
IN PIN. ■ E?D PIN. . . L0/*3.10 

55 PIN.-■lQ/*3 * SO 
3b PIN. * . 10/*5-5.Q 


54 PIN...10/*3. 
40 PIN...10/*k. 


'O&W 



r“i 

HOOD 




(LTD cm' SPECIAL: 18 Pin 8/S150 | 




DISCOUNT: Buy 10, take 10\ V 
Buy 100* take 20V. % 

We just got n batch of low power and fast £ 
(450 ns maximum- - full temp range) 2102L1 £ 

static RAMn► Perfect for memory boards-- ;j; 
and at our usual reasonable price: $1,951 | 

j; [ ft J ft ft ft: vftft-ftftffi-: ■:■: ■:■:■; vftftftvftftyftyfty: : ft y. ft.y.yy.v.y , vv ,-.y .y; y> . 

v ' k L h v ■' 1 ^ r ' rl ■■)mw«iuii naBnnn « aa * BHHHH M v" 

£;j | .Oil ACCURACY IN A TO-5 CAW...not , j-j 

C:-: | just useful for fixed frequency os■ | 

I cniators. 




* 1-flQflDA, 3.-6215, AND AN IS 

£ MHZ CRYSTAL AT A SAVINGS OVER INDI- 
K VI DU A L PRICES: FORtlS THE CORE OF 
A DUALITY SOflOA CPU BOARD- 

M 

:■ - - v...::.■■■ ".■. 5 ■. -.■. 


Multi Meter — 


S 

:^An outstanding buy, ,,4 DC Volt ranges, 

£5 DC current, S AC Volts, 2 ohms, and®! 
£dfc scale too. SO uA movement; plus* 
^"off" position damps meter for safe 
^transportation. Includes 34 inch test 
pleads hut less 1 AA battery, Small-- 
^a compact §k" x 3^j" x 1 S/B". 

;-fPlease add Si postage and handling. 


I 

§£■: ! 

m \ 
* 
i 
t 
i 
t 
i 
i 
■ 
i 
i 


since most numbers can I 
be used with simple binary dividers I 
to generate Other frequencies. ; 
For example, 15-360 can divide down | 
to 60 H z for timing pulse purposes; I 


We took everything we learnec from, selling ^sCxS HAH boards for 
the past year, added some of this year's circuit tricks* and 
cane up with EC0NQRA1- a memory board that is even more re¬ 

markable due to its low price. We've engineered this with the 
user in mind, giving you several benefits: 

* 3 regulators to share power load, plus optiml zed thermal de¬ 
sign, means a cooler running microcomputer 

* Typical current consumptIon of under 750 ma gives your power 
supply a break 

* Fast — Zero wait states 

* All TTL supibort ICs are latest Low Power Schottky types 

4 For reliable and unambiguous date transfer, all addresses, 
data lines, and outputs are buffered for minimum loading and 
maximum output capability 

* Power-on clear included 

AH these features are packed on to an Ai ta i r-s Ezed* industrial 
quality double-sided PC board, with sockets for all ICs, 1 tan¬ 
talum: capacitors For power supply decoupling, and plenty of by¬ 
pass capacitors---35 of them* In fact, as well as a logic print 
and instructions, 

also available assembled $129.95 

Our popular ECONORAM 4KxS RAM board is now available 
assembled, tested, and warranteed for one year, Plug 
it in to your Altair or IMSAI and enjoy the same per¬ 
formance that has made the kit such a success?--guar¬ 
anteed Kero wait states and current drain of 750 mA 
or less; on board regulation* easy address selection, 
and lots more. 




16,30 1 * divided by 2 l " gives 
l Hz timing pulses; *nd so on. All 
frequencies SA, 95 apply tC dis* 
count schedule for quantities. ALL 
FREQUENCIES IN KHz. 


i ilfimLS 


Choose from: 



SENTRy CRYSTALS-- 
54,95 PER CRYSTAL 
:£■: Series mode, fundamental, wire leads, 
for bams and computer bugs. Choose 
from 4 HHz {PACE clock crystal), 5 MHz 
g; 8 MHz, TQNHz, 12 MHz, T5rtHz, Ifl ME* 
(8030 dock crystal), and 2Q HHz. 


10.000 

12 * 8Q0 

15.000 1 

10.000 

18,384 

1 

18.041 

19,200 

2Q.4ttO [ 



30.720 | 

31,500 

32.768 

1 

:ik . 100 

40.060 

60.000 1 

743.800 

100,00 

153.60 * 

— — — _ 

240,00 

1 

_- *4 


i as* 

I 






:£j:K 

m 




"EconoRom" {179.95 

ALTAIR 88G0/IMSAI PLUG-IN COMPATIBLE. This is a 4K 
by 8 ER0M board...the ideal place for putting soft¬ 
ware, be it assembler, editor, or any custom set □£ 
routines. Additionally, this board may expand to 
8Kx8 by simply adding core sockets and EROKs; also 
available is a 2K x 8 version if you don' t need a 
full 4K. LOW POWER: 8K board requires @ 5V, & 
150 ma H -12V. Buffered addresses for lightest 
loading, buffered outputs for maximum drive. Kit 
includes sockets* double ^ sided quality PC board, 
on board regulators, logic print, and instructions. 
Program it yourself, or have us do the programing. 

8KX8 BOARD *269.95 2KX8 BOARD *155.00 

8080 lofftoore Board S189.95 

We took our ECQhQRQM board kTi* but Instead of including 
blank E&ON 5 , these are programned with assembler* editor* A 
monitor routines for the BOSG. This E* a valuable first *tep 
if you're trying toget away from machine language programing. 
There ' S- not really enough room here to fully describe all the 
functions of the software...but If you fend us $ 2,95 (refund¬ 
able with order)* we'll send you our software packet that in¬ 
cludes Instructions listing* schematic* and assembly data. 


SfigS 

mi 

M 

mi 

m 




\ .. T ..r, ■ ’’ r k , r Q ■ ' ...... . . ... . 






































Many of the terminals require 
special functions to effect 
proper line-oriented output 
displays. 

All these variables increase 
the desirability of a single 
terminal input service routine 
built into the operating sys¬ 
tem. If all user programs 
request terminal input via this 
monitor routine then, if the 
user ever adds a new terminal 
device to the system (see. Fig. 
2), he merely has to change 
the one handler. As the 
operating system gets more 
sophisticated, the terminal 
service routine can be 
expanded to include multi¬ 
ple-device handlers, interrupt 
driven input systems, and 
control of multiple jobs in a 
time sharing environment 
The limit of expansion is up 
to you. In any case, even the 
most basic operating system 
requires the handling of input 
from your terminal and since 
this is a reasonably complex 
procedure, it should be made 
available for other programs 
to share. Also, if you get 
involved in the automatic 
command processing system 
described in a later section, 
you will need to funnel all 
terminal input through a 
common routine for proper 
operation. 

Logical I/O Routines 

Most programs written for 
data handling require the data 
to be read and/or written 
from one or more peripheral 
devices. On your system you 
may start out with naught 
but a lonely terminal but 
eventually you will move up 
to the big time with cassettes, 
floppy disks, and all sorts of 
other diabolical devices 
designed to shuffle bits 
around in and out of your 
central processor. The variety 
of schemes which must be 
used to untangle and make 
sense out of these bits and 
pieces is enough to put all but 
the most stalwart of enthusi¬ 
asts away where white coats 
are the fashion of the day. If 
you go through these gyra¬ 
tions each time you write 
another program, you either 
are trying out for the 
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Fig. 3. Typical I/O System block diagram. 


"Harrassed Man of the Year" 
award or you have not yet 
heard of the concept of 
centralized logical I/O proces¬ 
sing. This is merely a fancy 
buzzword for a very simple 
and practical approach to 
handling these various periph¬ 
eral devices. You design a 
single set of monitor calls 
such as OPEN, READ, 
WRITE, and CLOSE and use 
these calls in your programs 
each time you wish to read or 
write data from somer periph¬ 
eral device (see Fig. 3). You 
inform the monitor which 
device you wish to use (there 
are various ways to do this) 
and the monitor I/O routines 
do all the dirty work. 

Sound simple? Well, 
almost but not quite. Many 
of the more sophisticated 
devices have certain funny 
little quirks built into them, 
such as floppy disks which 
require more detailed infor¬ 
mation to be given before the 
specific data can be located 
and processed. Disks in par¬ 
ticular must be structured in 
some logical manner to allow 
the data to be stored in little 
chunks commonly referred to 
as fifes. These files should be 
referenced by some meaning¬ 
ful name instead of an abso¬ 
lute location on the disk (and 
so the plot thickens as the file 
structure develops). The pro¬ 
gram should be written to 
process data from the most 
complex device that is 


expected to be used; and 
then, the monitor should be 
designed to recognize the fact 
that the simpler devices (such 
as a paper tape reader) do not 
need these additional argu¬ 
ments and to discard such 
devices. Since this is a 
complete subject in itself it 
will be dealt with in more 
detail in a future article. The 
main point to be remembered 
here is that by starting out 
with some predefined I/O 
structure, no matter how 
limited it may be initially, 
additional devices may be 
added to your system by 
merely writing a new monitor 
driver (routine) to interface 
to that device. All programs 
which have been written 
using your I/O calls can then 
access the new device without 
alteration. 

Command Level Processor 
An operating system is 
only as good as the assistance 
it can provide to the person 
using it. A way must exist for 
the system to fully under¬ 
stand what is expected of it if 
it is to perform properly. The 
orders that are given to a 
computer are called com¬ 
mands and can range from a 
meaningless string of special 
characters designed to 
appease the machine's thirst 
for complexity to a set of 
straightforward English words 
which get the job done. 
Again, as always, there are 


tradeoffs to be considered. 
The evaluation of single 
characters is a lot simpler 
than the evaluation of com¬ 
plete words which may vary 
in length and position. The 
obvious tradeoff in the other 
direction is that words are a 
lot easier to understand than 
special characters, especially 
if you are not used to talking 
in gibberish. The functions to 
be performed by the operat¬ 
ing system will also contrib¬ 
ute greatly to the design of 
the command language. If the 
command words are to be 
stored in some sort of table 
within the monitor, they 
should be as concise as pos¬ 
sible (which heads us right 
back in the direction we are 
trying to avoid). Also, if we 
use specific commands to 
perform internal system 
functions, the monitor itself 
must be regenerated each 
time a new command is 
implemented. 

The method which I am 
about to propose is not total¬ 
ly unique in itself but does 
have some interesting points 
which make it worthwhile. 
Instead of having a set of 
specific commands which 
perform internal system 
functions, why not just treat 
each command as the name 
of a program and have the 
monitor load and then exe¬ 
cute that program? The the 
commands themselves need 
not be stored within the 
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monitor, and the implementa- 
tion of new commands 
merely involves the creation 
of the program to perform 
the command function. This 
method is most advantageous 
when used in a disk-based 
operation since the programs 
can be stored on the disk and 
loaded at high speed by the 
monitor routines. I have also 
used the same idea with sys¬ 
tems that did not have a disk 
but, instead, treated main 
memory as the program 
storage area. It was then up 
to me to ensure that the 
program being executed was 
loaded (from cassette, paper 
tape, etc.) by the monitor 
before executing the com¬ 
mand which invoked it Such 
a system must allow multiple 
programs to be held in memo¬ 
ry at one time in order to be 
effective. 

Disk Management 

Keeping track of programs 
and data which are stored on 
floppy disks is an entire 
science in itself. Data stored 
on a cassette is written as a 
single stream of sequential 
characters from start to finish 
either in one chunk or a series 
of chunks referred to as 
records. Reading this data 
back into the computer 
merely involves backing up 
the tape to the beginning and 
then reading the records in 
the same order in which they 
were written. Data stored on 
a disk, however, can take on 
several different formats and 
be accessed in a number of 
ways, depending on the appli¬ 
cation in use. Reading data 
from disk does not set the 
limitation of retrieval in the 
same order as it was written. 
You also have the ability to 
select only portions of data 
and write or rewrite without 
changing all the rest of the 
records associated with it. A 
disk can be likened to a 
slower extension of main 
memory in some of its capa¬ 
bilities and therefore will 
require some special routines 
to efficiently store and 
retrieve data from it. 

For the sake of clarity, I 
will direct my next state¬ 


ments toward the most popu¬ 
lar devices currently available 
to the hobbyist — the floppy 
disks. Data is read and writ¬ 
ten on these disks in fixed- 
length records, each record 
containing 128 bytes, this 
collection of records (called a 
fife) can consist of an entire 
program to be executed or of 
a series of ASCII characters 
which comprise the source 
program before assembling or 
compiling. The file might also 
be just a random ordering of 
data used by some of the 
programs in any format the 
programmer desires. Since 
each disk can store around 
2000 records (each 128 bytes 
long), it would be a waste of 
space if a system only 
allowed one file to be on each 
disk at any one time. There 
are many popular schemes 
available for the ordering and 
accessing of these files on the 
disk and each has its merits 
for particular applications. 
The tradeoffs which the 
hobbyist must make in order 
to implement an efficient, yet 
inexpensive, system (memo¬ 
ry-usage wise) will be dis¬ 
cussed in a future article 
dedicated to file organization 
techniques for microproces¬ 
sor systems. Since this series 
of articles is aimed to an 
eventual disk-based system, 
most of the ideas presented 
will be centered around the 
use of the disk for program 
and data file storage. The 
reader who is not yet into 
disk systems can still use 
many of the ideas presented 
here for manipulating files in 
main memory; he will then 
have a better understanding 
of large system techniques 
when he eventually moves up 
to a disk-based operating 
system. 

Numeric Conversion Routines 
One of the areas that the 
novice who starts to write his 
first monitor may overlook is 
the incorporation of numferic 
conversion routines into his 
monitor which can be used 
by all running programs. Here 
cleverness and forethought 
can really save both develop¬ 


ment and execution time. 
Almost all numeric data is 
stored and manipulated in 
binary within the computer 
yet must be accepted and 
displayed to the outside 
world in a familiar format. 
This format may be decimal, 
for the most common appli¬ 
cations, or octal or hexadeci¬ 
mal, for the exotic system 
debugging that invariably 
entices everyone into its trap. 
After all, what fun is a com¬ 
puter if you can't jump into 
its weird world of funny 
numbers once in a while? 

The process of converting 
from one numeric format to 
another can take on many 
coding forms and is an area 
where the programmer can 
express his innovative abili¬ 
ties. The duplication of this 
effort into each and every 
program soon becomes 
boring, however, and you will 
soon find yourself looking for 
a way around the problem of 
inputting and outputting 
numeric data. If these rou¬ 
tines can be put into the 
monitor and then called by 
the programs, the time saved 
in the development of new 
programs will be significant. 
The question is, how many 
different routines should we 
incorporate, and how fancy 
do we make each one? The 
decision is yours, and it will 
depend on the frequency of 
usage and the importance you 
place on the formatting capa¬ 
bilities of the data routines. 
Such frills as leading and trail¬ 
ing zero suppression, decimal 
point handling, and space 
positioning are neat, but they 
do require memory, of 
course. Normal usage will 
probably dictate that the 
fancy frills, if any, be incor¬ 
porated into the decimal data 
routines and the straight¬ 
forward "no frills" method 
be used for octal or hexadeci¬ 
mal conversions. If you insist 
on working with funny 
numbers, you probably won't 
mind roughing it for awhile. 

Memory Management 

Any task that is to be 
performed by the computer 
will require the use of main 


memory for program execu¬ 
tion and immediate data 
manipulation. The easier the 
operating system can make 
the task of managing the 
available memory resources, 
the easier it will be for you to 
develop new programs. The 
operating system must have a 
few basic routines for its own 
use so that programs can be 
loaded into their proper 
places and work buffers can 
be allocated for system func¬ 
tions (see Fig. 4). Routines 
which inform the user pro¬ 
gram of where the available 
memory is located and how 
much memory is free for its 
use are helpful, especially in 
systems where the amount of 
available memory changes on 
a regular basis. More sophisti¬ 
cated techniques can be 
devised that allow the pro¬ 
gram to request a specific 
amount of memory for work 
space and allow the monitor 
to allocate that memory 
wherever it happens to be 
free at the time. 

There are many techniques 
that can be employed for the 
efficient management of main 
memory resources and most 
of the decisions in this area 
will be based upon the type 
of hardware in use. Certain 
processors inherently have 
more flexible instruction sets 
which lend themselves to 
fancy memory allocation 
schemes. Probably the most 
easily adaptable systems are 
those processors that allow 
various degrees of instruction 
relocatability. This is another 
fancy term which merely 
means that the processor has 
been designed so that either 
some selected portion or all 
of the instructions may be 
freely moved about in memo¬ 
ry without the need to 
reassemble the program to 
execute it. Indexing and 
PC-relative techniques are the 
tools which many manufac¬ 
turers use to implement some 
level of instruction relocat- 
ability and the method that 
you employ in your operating 
system and to what level you 
employ it will depend greatly 
on this. This is another arena 


73 



in which the creative gladia- 
tor will eventually come out 
on top. 

Keep It Simple 

There are no secret 
weapons to use in the design 
of a monitor nor are there 
any giants to be killed 
in one fell swoop. A good 
system will normally start out 
as a few simple routines that 
are necessary to get the basic 
job done and then expand 
gradually as the wizardry and 
courage of the programmer 
grows. To start out with a 
design that incorporates all 
the frills that could possibly 
be desired in an operating 
system is inviting frustration 
and possible failure. An 
operating system should grow 
in small steps like a stamp 
collection. In turn, this will 
give a continuing flow of 
creative feedback which never 
hurt anyone, i hope to be 
able to give sufficient inspira¬ 
tion in the areas of operating 
system design. The objective 
is to encourage experimenta¬ 
tion in this fascinating field 



rather than set down a few 
hardfast techniques which are 
to be considered the best for 
everyone. And by all means, 
let's not forget the cardinal 
rule of any hobby; Share 


your knowledge with others. 
There are very few ideas 
which I would call entirely 
my own while keeping a 
straight face. I continually 
give open thanks to all those 


who have gone before me and 
contributed to the back¬ 
ground that allows me to 
twist, bend, fold, staple (and 
sometimes mutilate) the 
techniques I now use freely. ■ 
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Meet The Digital Group 


II you lire seriously considering the purchase of a microcomputer 
system for personal or business use . or just beginning lo fee] 
the first twinges of interest in a fascinating hobby,, the Digital 
Group is a company you should get acquainted with. 

For many months now, we've been feverishly (and rather quietly) 
at work on our unique, high-quality product —a microcomputer 
system designed from the inside out to be the most comprehen¬ 
sive, easy-to-use and adaptable system you'll find anywhere. And 
our reputation has been getting around frtsf. in fact, you may have 
already heard a little something about us from a friend. We've 
found our own best salesmen are our many satisfied customers. 

There's a good reason. Simply, the Digital Group has a lot to offer 
state-of-the-art designs, a totally complete systems philosophy, 
unexcelled quality, reasonable software, affordable prices and the 
promise that our products will not become rapidly obsolete, even 
in this fast-moving, high-technology field, 

The Advantages 

Here are a few specific advantages of our product tine; 

* We offer interchangeable CPUs from different manufacturers 
(including the new "super chip" —the Z-80 from Zilog) which 
are interchangeable at the CPU card level. That way, your 
system won't become instantly obsolete with each new design 
breakthrough. The major portion of your investment in mem¬ 
ory and I/O is protected, 

* Digital Group systems are complete and fully featured, so 
there's no need to purchase bits and pieces from different manu¬ 
facturers, We have everything you need, but almost any other 
equipment can be easily supported, too, thanks to the uni¬ 
versal nature of our systems. 

* Our systems are specifically designed to bo easy to use. 
With our combination of TV, keyboard, and cassette recorder, 
you have a system that is quick, quiet, and inexpensive. To get 
going merely power on, load cassette and go! 

* Design shortcuts have been avoided —all CPUs run at full 
maximum rated speed. 

* All system components are available with our beautiful new 
custom cabinets. And every new product will maintain the 
same unmistakable Digital Group image. 

The Features 

Digital Group Systems —CPUs currently being delivered: Z-80 by 
Zilog 8OS0A/9O8OA 6300 6500 by MOS Technology 

All are completely interchangeable at the CPU card level. Standard 
features with all systems: 

* Video-based operating system 


* V i de o / Casse tte I n t erf ace Ca rd 

512 character upper & lower case video interface 
100 character/second audio Ciissette interface 

* CPU Card 

2K RAM, Direct Memory Access (DMA) 

Vectored Interrupts (up to 128) 

256 byte 1702A bootstrap loader 

Alt buffering, CPU dependencies, and housekeeping 
circuitry 

* Input/Output Card 

Four8-bit parallel input ports 
Four 8-bit parallel output ports 

* Motherboard 

Prices for standard systems including the above features start at 
$475 tor Z-80, S423 for 8080 or 6800, $375 for 6500. 

More 

Many options, peripherals, expansion capabilities and accessories 
are already available. They include rapid computer-controlled cas¬ 
sette drives for mass storage, memory, I/O, monitors, prom boards, 
multiple power supplies, prototyping cards and others. Software 
packages include BASICs, Assemblers, games, ham radio appli¬ 
cations, software training cassettes, system packages and more 
(even biorhythm), 

Sounds neat —now what? 

Now that you know a little about who we are and what we're 
doing, we need to know more about you. In order for us to get 
more information to you, please take a few seconds and fill in our 
mailing list coupon. We think you'll be pleased with what you 
get back. 



DO, Box 6520 
Denver, Colorado flt)20b 
( 305 ) 777-7133 


OK, I'd like to get to know you guys better, 
bend me the whole package! 

Name___ 

Address____ 

City/State/Zip.______ 











W hen you receive a 
program from anoth¬ 
er personal computer user or 
from a manufacturer, more 
often than not it will require 
modification before it will 
run on your system. The wide 
variety of configurations and 
choice of input and output 
devices make it impractical to 
write a program that will run 
on any system without 
modification. That goal is 
seldom obtainable because, if 
it had to have routines to 
drive every kind of device 
known, even the simplest pro¬ 
gram would become too large 
to fit into most computers. 
Furthermore, any enterpris¬ 
ing company could obsolete 
the software by merely 
inventing a new I/O device. 
And, it seems this happens 
nearly every day. The large 
computer manufacturers try 
to solve the problem with 
"do everything" operating 
systems. But they don't mind 


selling megabyte memories to 
their customers, and the cus¬ 
tomers (usually not knowing 
how much of their memory is 
being wasted) think that the 
large system software's size is 
giving them much more 
power. This is a trap we can't 
afford. 

Fortunately, it is possible 
to set up standards, all of 
which are generally con¬ 
sidered good programming 
practice, that make it easy to 
interchange any program 
from one machine to another. 
There are some limitations: If 
the program is in assembly 
language then, of course, the 
two machines must have the 
same instruction set. 
(Although, as we will see, 
programs can be written in 
such a way as to facilitate 
interchange between different 
instructions sets.) If the pro¬ 
gram is in a higher level lan¬ 
guage, then machine depen¬ 
dent tricks (such as PEEK, 


POKE, INP and OUT in MITS 
BASIC) cannot be used. 
(Later on we will detail ways 
in which they can be used 
and still maintain ease of 
transfer.) 

I/O Configuring 

If your program is design¬ 
ed to work only with a partic¬ 
ular I/O device then say so in 
your program writeup. But 
most programs will work 
equally well with a Teletype, 
Flexowriter, CRT terminal or 
Video Display device. The 
fundamental rule to ensure 
this capability is that the 
main program must do no I/O 
whatsoever 

All input and output 
should be done from subrou¬ 
tines. For any device at most 
four subroutines are required. 
A set is written for each 
device. 

1. START. This subroutine 
does any initialization re¬ 


quired by the device. Many 
serial ports with a UART 
require initialization. Some 
cassette interfaces require a 
start byte and/or a sync byte. 
You often have to throw 
away a random character sit¬ 
ting in an input or output 
buffer and, in some cases, a 
delay may be needed for a 
device to come up to speed. 
Anything that must be done 
once before a device can be 
used for input or output is 
done in this routine. 

2. GET. For devices that 
send bytes to the CPU only. 
This routine, when called, 
returns one byte of data from 
the input device. Any hand¬ 
shaking, waiting, or control 
codes that must be setup for 
each byte are done in this 
routine. As far as the main 
program is concerned this 
routine is a magic box that 
delivers one byte when called. 
A protocol for determining 


Solving Some of the 
Software Interchange 

Problems 


Jef Raskin 
Box 511 

Brisbane CA 94005 


We're going to make the Kilobaud Software Library work. In the short time it will take to 
get the thing going into full swing, we're going to be publishing a series of articles dealing with 
the software interchange standards this effort will require. Naturally, we'd be very interested in 
reader responses to these articles and the ideas they put forth. Jef Raskin emphasizes the 
interchange of BASIC programs in die following article and touches upon assembly language 
programs also. He has some points which make such good sense your first reaction is, "Well of 
course that's the way it should be." I'm sure he's developed these ideas from his many years of 
playing with these monsters. Aside from being an ex-Computer Center Director at UC San 
Diego, he has taught courses in programming fof course), computer animation, and computer 
music. And, would you believe that his basement contains an Aftair 8800, an IMSAI, an Apple, 
and a Poly 88? / have this strong feeling we're going to be hearing more from him. — John. 
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and so on ... strange byte, or change it to 

A good BASIC subroutine another code for his or her 
form is shown in Fig. 2. CRT. If you don't include the 


REM SUBROUTINE TO.(explain what it does) 

REM IT WORKS BY ... . (explain how it does it) 

REM IT NEEDS THE FOLLOWING VARIABLES . . . (list all inputs to the routine) 
REM IT CHANGES THE FOLLOWING VARIABLES . . (all internal and returned names) 
REM IT IS REQUIRED BY THESE SUBROUTIKES . . (everything that calls it) 

REH IT REQUIRES SUBROUTINES .... (everything that it calls) 

then the rest of the subroutine. r/ff. 2. 


Avoid using statement REMARK, then the next user 


when a device is done must 
be established Usually a final 
delimiter in the input stream 
or an initial byte or two 
giving the length of the infor¬ 
mation to follow will do the 
trick. 

3. PUT. For devices that 
receive bytes from the CPU. 
This routine, when called, 
sends one byte to the output 
device. Any handshaking or 
timing or control codes that 
must be sent for each byte is 
done in this routine. 

4. FINISH. Occasionally, a 
device must be turned off 
after it is used. This routine 
will perform that function 
when necessary* 

An analogous set of rou¬ 
tines is required for some 
mass storage systems, such as 
disks, except that in this case 
a block of memory rather 
than a single byte is the 
burden of the routine. None 
of these I/O conventions will 
be of any use whatever, 
though, unless the programs 
are well documented. Docu¬ 
mentation is another distinct 
area which needs minimum 
standards badly. 

When a program is ob¬ 
tained and, if the above stan¬ 
dards are adhered to, the user 
will merely (ha) have to find 
(from the accompanying 
documentation) where the 
I/O subroutines are in the 
program. If the program was 
written correctly there will be 
no other I/O routines in the 
program and there will be 
only one START, GET, PUT, 
and FINISH for each device. 
These small subroutines will 
then have to be modified or 
replaced with routines 
designed for the user's I/O 
gear.. This will be especially 
easy if no "hard" device 
codes or control or status 
bytes are used. That is, if 
instead of a constant being 
used in an I/O instruction, a 
variable is used whose value is 


set in the START program. 
This is good programming 
practice in any case. The 
same applies to addresses. 
"Soft" or relocatable code 
(unfortunately not available 
on some of the rather primi¬ 
tive assemblers) makes cus¬ 
tomizing easier. 

Avoiding Tricks 

We all love to be clever in 
writing programs. And any¬ 
body who has programmed 
for a while can come up with 
some neat "hacks" that do an 
operation in an unexpected 
way. Of course, being a good 
programmer you realize that 
someone reading your pro¬ 
gram won't take the time to 
figure out what you have 
really done. They will simply 
shake their heads in wonder¬ 
ment and proceed to modify 
the program in such a way 
that it will never work again I 
Since the aim of program¬ 
ming is not to impress your 
peers but to create something 
that works and is reliable 
(yes, software can be made to 
be reliable or unreliable just 
like lawnmowers or refrigera¬ 
tors), the programmer should 
avoid tricks. If a "trick" 
seems to give your program a 
decided advantage, then be 
sure to fully explain what 
you have done. One byte 
saved by a clever trick will 
usually require three or four 
fines of explanation. Don't 
assume the readers of your 
program will know what you 
were thinking. They won't. 
This is true in higher level 
languages, such as BASIC, but 
is especially true in assembly 
language. Remember that it is 
easier, given good documenta¬ 
tion, to recreate a program 
than it is to create the 
documentation given the pro¬ 
gram! 

Interchangeable BASIC Soft¬ 
ware 

A good BASIC main pro¬ 
gram form is shown in Fig. 1. 


types that are local to the 
BASIC that you happen to be 
using. This means that you 
have to know what a * few 
different BASIC dialects look 
like. In general DATA, DEF, 
DIM, END, FOR, GOTO, 
GOSUB, IF ... GOTO, 
INPUT, LET, NEXT, PRINT, 
READ, REM, RETURN, and 
STOP are included in every 
nonTiny BASIC. Functions 
that you can use safely are 
ABS, INT, RND (usually), 
SIN, SQR, and almost all full 
BASIC interpreters include 
COS, ATN, EXP, LOG, and 
TAN. All other statement 
types should be carefully 
explained so that the new 
users can implement the 
equivalent in their language. 
Segregate special statements 
into a few subroutines. They 
should never be part of the 
main program. If you write 
your BASIC programs as out¬ 
lined here, your name will 
shine in the hearts of anyone 
who tries to use your pro¬ 
grams. If not, you will be 
cursed in foul language 
known only to those frustrat¬ 
ed by hours of trying to 
outguess you. Programs 
should not be puzzles. 

The section on I/O also 
applies to BASIC. In other 
words, put all I/O in subrou¬ 
tines. GET and PUT, as well 
as START and FINISH, are 
often not appropriate in 
BASIC. But, if you use MITS' 
OUT function, for example, 
be sure to use a variable for 
the device number and 
similarly for the WAIT mask 
and control port number. If 
you are writing for a CRT 
terminal and you need a 
special byte to erase the 
screen, make the value of that 
byte a variable, and make a 
conspicuous REMARK 
explaining what it is doing. 
The next user can then either 
eliminate the erase with that 


won't know whether it is a 
special start-up code, rings 
the bell, or just patches 
around a bug in your system. 

If a program has too many 
REMARKS to fit in your 
computer, save the source 
listing with the remarks and 
make a copy on paper or 
magnetic tape to run without 
the comments. When writing, 
create each program segment 
with full REMARKS, save the 
subroutine after testing it, 
and then, if you must to save 
space, eliminate the remarks 
from the copy in use. Keep a 
fully documented source list¬ 
ing and if you send your 
program to a fellow hobbyist 
(or to the Kilobaud Software 
Library), send the fully docu¬ 
mented version . You may 
also send a compressed ver¬ 
sion, but that is not nearly as 
important. 

Assembler Level Interchange- 
ability Between MPUs 

There is only one way: 
Excellent docu mentation 
(Where have you heard that 
before?). Extensive use of 
flowcharts helps, too. An¬ 
other advantage is breaking 
down the program into small 
routines, each of which is 
easy to program from scratch. 

Some of the features needed 
in a good document are: 
Registers used, location and 
order of arguments, other 
stack usage, flags affected, 
and anything else that could 
affect any other program that 
might become part of the 
system. I won't go into a 
dissertation on the usual good 
practice of saving and re¬ 
storing all registers, pointers, 
and flags whenever entering 
and leaving a subroutine. And 
then there is the problem of 
interrupts. Another day for 
that one. 

Summary 

Document like crazy. ■ 


REM 




REM 

Explain the overall program 



REM 

REM 

GOSUB 

What the first routine does 



REM 

Where vc are now - c.g., what has been calculated. 

or input. 

etc. 

REM 

GOSUB 

What the next subroutine docs 



REM 

Where we arc now 



REM 

GOSUB 

What the next subroutine does 

Fig. 

f. 
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Too many of us are stilt 
toggling programs and short 
routines in by hand. The time 
is tong past for getting some 
sophistication into this opera¬ 
tion ... and Mike Aronson 
has a good introduction here 
to ASSEMBLIES ... one way 
of doing just that Once you 
begin using an assembler and 
the mnemonics (symbolic 
codeI for the various instruc¬ 
tions instead of octal or hexa¬ 
decimal machine code, you'll 
wonder how you ever got 
along without one. Mike 
comes up with some very 
interesting points here, in¬ 
cluding some "don'ts", one 
of which is a program that 
modifies itself (bad news). He 
also defines a relocatable pro¬ 
gram by showing us why and 
how one can and can't be 
(did anyone understand 
tha t?). His article really 
timely now that assemblers 
are becoming more and more 
available for hobby systems. 
— John. 


Mike Aronson 
156 Donald St 
Oregon City OR 97045 


S uppose a married couple 
went away for a week 
and left their teenage children 
in charge of the house. In 
most homes, a simple "Take 
care of the house while we 
are gone/' would not be suf¬ 
ficient to keep the house on 
the lot for three days, let 
alone one week. So, the 
parents scheme in advance. 
Notes are prepared and left 
where their kids will find 
them. 

"Put your dirty socks 
down the laundry chute/' is 
attached to the record player. 
Just to make sure the job gets 
done, another note is taped 
to the inside of the hamper 
door. 

"If you want to find the 
turntable spindle, wash the 
dirty dishes." Naturally, the 
spindle and another note are 
attached to the detergent. 

"If you want to find the 
keys to the car, make your 
bed." As they do each job 


correctly, the reluctant 
housekeepers find new and 
explicit instructions which 
take them through the week. 
(But be careful if you try this 
type of reward system. 
Instead of a neat and tidy 
house, you might return to 
find your children have 
organized a treasure hunt for 
you\) 

A new computer hobbyist, 
who has just finished building 
a microcomputer kit, has 
exactly the same problem as 
he or she connects up a ter¬ 
minal and turns it on. Sup¬ 
pose you decide the first 
thing you want to do with 
your beautiful, humming 
machine is to put eight zeros 
into every byte of memory. 
What do you do? You can't 
type "please clear memory" 
because the computer needs 
explicit instructions. You will 
have to write a series of state¬ 
ments that breaks the job up 
into small tasks that your 
machine can handle. This is 


called writing a program. 
There are, however, two little 
annoying problems: 1) The 
computer doesn't understand 
English, it speaks machine 
language. (Machine language 
is composed of ones and 
zeros - very boring.) 2) You 
can't be present while the 
computer follows your pro¬ 
gram. If you have made 
mistakes, the computer won't 
stop and ask questions. It wilt 
execute your program even 
though it is incorrect. 

If you are a beginner, 
don't throw up your hands 
and give up. You can buy a 
computer program, that 
somebody else has written, 
which will allow you to talk 
to your machine. This is 
called an assembler program. 
Most assemblers are not very 
sophisticated. (That means 
they can't speak English 
either!) So you have to learn 
how to talk to an assembler 
program. Once you have 
mastered that, the assembler 
program will translate your 
programs into machine lan¬ 
guage for you. That solves the 
first problem. As for the 
second problem, well, 
nobody's perfect. My advice 
is, don't let the possibility of 
making some mistakes stand 
in the way of writing your 
own programs. This article 
will help you read and write 
simple programs for an 8080 
assembler. Just remember, as 
you go on, there are three 
steps to computer program¬ 
ming: 1) decide the type and 
order of instructions; 2) 
assemble the program into 
machine language; 3) execute 
the machine language pro¬ 
gram. 

First, let's take a look 
inside an 8080 chip (Fig. 1). 
(I've left out timing and some 
other functions that we don't 
need to worry about here.) 
Instructions and data come 
into the chip on an 8-bit 
parallel transmission line 
called the external data bus. 
These instructions and data 
are stored in memory loca¬ 
tions outside of the chip. The 
microprocessor can pick up 
its instructions and data by 
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e BITS 


0 BITS 
REGISTERS 


TO EXTERNAL MEMORY 
VIA THE EXTERNAL 
BIDIRECTIONAL 
DATA BUS 



INTERNAL DATA BUS 
8 BITS 


Fig. 1. Simplified 8080 block 
diagram. 


selecting a 16-bit address 
(from either the program 
counter or the instruction 
decoder) and sending it out 
on the address bus. Whatever 
is in that memory location 
will appear on the data bus. 
The reverse is also possible. 
The chip can send data to 
memory locations by select¬ 
ing an address and then 
presenting the data on the 
external data bus. The data 
will be stored at the selected 
location. The data bus is 
called bidirectional because 
data can flow in both direc¬ 
tions, in or out of the 8080. 

The internal data bus 
supplies communication 
between the instruction 
decoder and four other units. 
The arithmetic logic unit 
contains the rules for addi¬ 
tion, subtraction, and how to 
perform logic operations. Six 
8-bit registers are tied togeth¬ 
er into another unit of three 
pairs. They can be used as 
either 8- or 16-bit registers. 
The accumulator, a special 
8-bit register used for arith¬ 
metic operations, can also be 
used for temporary data 
storage. There are five flip- 
flops called flags; we will only 
use three of them. One flag is 
set if the value of your last 
arithmetic operation is zero. 
For example, the result of a 
subtraction may be zero, or 
the contents of register C 


may be made zero by a sub¬ 
traction. Whenever any arith¬ 
metic operation results in a 
value of zero, the zero flag is 
set A second flag is set if the 
answer to the last arithmetic 
operation was a negative 
number. The third flag, the 
carry flag, is set if you 
attempt to put a binary 
number bigger than 8 bits 
into the accumulator. One 
example of this would be 
when two numbers are 
summed, causing an overflow. 
This flag is also set if a 
subtraction required "bor¬ 
rowing" from a place higher 
than the eighth bit. Flags 
retain the value they are set 
to until another arithmetic 
instruction changes them. 
They can be interrogated 
between arithmetic instruc¬ 
tions and decisions may be 
based on their value. There 
are many examples of this 
later in the article. 

Note, however, what is not 
inside an 8080 chip — there is 
no place to store a program. 
Program instructions and data 
are stored in the same place, 
external memory. 

Now take a look at Table 
1. I've selected some instruc¬ 
tions that an assembler pro¬ 
gram recognizes. They are 
called data transfers because 
they move data from one 
register to another. The 


instruction decoder decides 
what goes where. Let's try to 
write our memory clearing 
program using these instruc¬ 
tions. Suppose that we 
wanted to clear out one 
particular memory byte. Let's 
say the contents of memory 
at address 640 is to be 
zeroed. The microprocessor 
must put the 16-bit code that 
corresponds to 640 on the 
address bus and all zeros on 
the external data bus. But 
that is at execution time, step 
3 of computer programming. 
We are still at step 1, deciding 
what instructions to use. So 
we jot this down on a piece 
of paper. 


MV I A 
0 

STA 

640 


Each line represents a 
single instruction or data. An 
assembler program would 
take this series of instructions 
and numbers, in the order I 
wrote them, and change them 
into machine language code 
(i.e., Is and 0s). If this 
machine language program 
were loaded into memory and 
executed, the first instruction 
would cause a zero to be 
placed into the accumulator 
(register A). The second 
instruction would store the 
contents of the accumulator 
in memory location 640. 

This is not a bad first try 


at writing a program. The last 
byte, however, could cause 
some confusion. Do we mean 
decimal 640 or octal 640? 
Assembler programs need to 
be told what kind of numbers 
you are writing. I use a # 
when I'm expressing a deci¬ 
mal number and no symbol 
when I use octal numbers in 
programs. 

There is another difficulty 
with the last instruction. STA 
instructions are supposed to 
be three bytes long. The 
reason for the extra two 
bytes is to have enough room 
to write a 16-bit address 
code. For an 8080 chip, the 
highest order bits are always 
put the furthest away from 
the instruction. For example, 
consider the decimal number, 
#640. In 16-bit binary it is 
written 0000001010000000. 
When converted to octal and 
two 8-bit values (i.e., divided 
in the middle), the least sig¬ 
nificant bits would be 200 
and the 8 most significant 
bits would be 002 (00 000 
010 10 000 000). If we 

rewrite our first program and 
remember to put the most 
significant bits of the octal 
numbers into the last byte, it 
would lo ok like this . 

MV I A 
000 
STA 
200 
002 

So this simple program is 
five bytes long. The assembler 
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would load this program into 
memory in five consecutive 
locations that are external to 
the processor chip. Once the 
program counter (see Fig. 1) 
is given the address of the 
first instruction of our pro¬ 
gram, the chip can take it 
from there. The instruction 
decoder will advance the 
program counter by the 
number given in the column 
called Bytes in Table 1. The 
address in the program 
counter, remember, is sent 
out on the address lines. Thus 
the decoder can skip over 
data that is mixed in with 
instructions. Only the first 
and third bytes, of the above 
program, contain instruc¬ 
tions. The other bytes con¬ 
tain "operands." An operand 
is any additional information 
(data or address) needed by 
an instruction. One-byte 
instructions don't have oper¬ 
ands. Two-byte instructions 
have one-byte operands. 
Three-bytes instructions have 
two-byte operands. If you are 
sitting near an 8080 type 
computer and have an assem¬ 
bler to load, try this program. 
Single step your computer to 
see how it works. 

This is a good time to stop 
and consolidate what we have 
done so far. 

Question: Suppose you 
turned on your computer for 
the first time, connected up a 
TV typewriter and typed 


Imvi a I 

and pushed the carriage 
return. The letters 
Imvi a I 

are readable on the TV 
screen. What was stored into 
the computer's memory? 

Answer: Nothing. There is 
no program in memory that 
recognizes what you did. 
What you see on the screen 
comes from the terminal 
itself, not the computer. 
There is a good chance that 
turning on the power to your 
computer put random data 
and instructions into mem¬ 
ory. Computer scientists have 
a technical word for this type 
of program — garbage. (And 
the chance that this garbage 
would write a machine lan¬ 
guage program that could 
accept your input is very 
small.) You must have a 
program in memory to accept 
data from a keyboard if you 
want to communicate with 
your computer. 

Question: Suppose you 
purchase an assembler pro¬ 
gram and load it into com¬ 
puter memory. Can you 
communicate with your 
computer now? 

Answer: Assuming you 
have bought a good assembler 
that is made for your ma¬ 
chine and keyboard combina¬ 
tion, you only have to do one 
more thing, execute the 
assembler program. Push the 
run/start switch. The assem¬ 


bler program is now running 
and waiting for input from 
the keyboard. 

Question: Suppose you 
load and execute an assem¬ 
bler program. Why can't you 
type 

PLEASE CLEAR MEMORY 

and expect the contents of 
memory to be zeroed? 

A ns wer:. I ntel decided 
what your 8080 chip could 
do when it designed the 
instruction decoder. As useful 
as this instruction might be to 
you, it isn't part of the 
instruction set. You must 
break the task up into 
instructions that the decoder 
can understand. 

Question: Suppose you 
wanted the assembler pro¬ 
gram to write a machine lan¬ 
guage instruction that would 
cause the number in register 
D to be moved to register E. 
What would be the input to 
the assembler? 

Answer: 

(mov e d] 

Question: Suppose you 
typed 

mvi c~ 

000 

as input for an assembler 
program. After you;v are 
through, what is the content 
of the C register? 

Answer: You don't know. 
All you have done is to store 
the machine language equiv¬ 
alent of 



somewhere into memory. The 
instruction will be executed 
at a later time (i.e., the 
instruction is not executed 
while it is being "assem¬ 
bled"). 

Question: Suppose you 
type _ 


MOV 

A & 

MVI 

B 

001 


LX I 

H 

020 


GOO 



as input to an assembler. How 
many bytes of memory will 
the machine language pro¬ 
gram occupy? 

Answer: Consult Table 1 if 
you are not sure how many 
bytes each instruction occu¬ 
pies. The total number of 
bytes is six. Notice operands 
are mixed in with instruc¬ 
tions. The instruction de¬ 
coder will be able to sort It 
out. 

Question: Suppose the 
previous program were loaded 
into memory and executed. 
After execution, what would 
be the contents of register L? 

Answer: The LX I H 
instruction put a 020 into 
register L. Consult Table 1 if 
you don't remember why. 

Memory refresh time is 
over. Now I'll show you how 
to write a PLEASE CLEAR 
MEMORY program. 

A MVI instruction always 
takes up two bytes of mem¬ 
ory and STA always takes 




Execution time in usee 




Without 

With 

Instructions to the microprocessor 

Mnemonic 

Bytes 

memory reference 

memory reference 

during execution 

MOV R lf R 2 

1 

2.5 

3.5 

Take the contents of register 2 and move it to 
register 1. (For example, MOV H,B would transfer 
the contents of B into H.) 

MVI R 

2 

3.5 

5.0 

Immediately after this instruction you will find 
one number. Move that number into register R. 

LX I R 

3 

3.0 

5.0 

Immediately after this instruction you will find 
two numbers. Load the second number into 
register R. (For this instruction R is valid only for 
registers 6, D, and H.) 





Load the first number into the register following R 
{see Fig. 1). 

STA 

3 

6.5 

- 

Store the contents of the accumulator into memo¬ 
ry. Use the address given in the next two bytes. 

LDA 

3 

6.5 

- 

Load the Accumulator from memory. The data is 
located at the address given in the next two bytes. 


Table 1. Short 8080 Instruction set: Data transfer instructions 
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Execution Time 

instructions to the microprocessor 

Mnemonic 

Bytes 

in usee 

during execution 

JZ 

3 

5.0 

If the result of your previous arithmetic instruction 
was the number zero, follow Rule A. If the result 
was not zero, follow Rule B. 

Rule A 

You must jump to the location specified by the 
next two bytes. 

Rule B 

Your next instruction will be found three bytes 
after this one. 

JNZ 

3 

5.0 

If the result of your previous arithmetic instruction 
was not zero, follow Rule A. If the result was zero, 
follow Rule 8. 

JP 

3 

5.0 

If the result of your previous arithmetic instruction 
was a positive number (0, + 1, +2, +3. etc,), follow 
Rule A. If the result was a negative number (-1, -2, 

-3, etc.), follow Rule B. 

JH 

3 

5.0 

If the result of your previous arithmetic instruction 
was negative, follow Rule A. If the result was 
positive, follow Rule B. 

JHP 

3 

6,0 

Follow Rule A (no decision to make). 

JC 

3 

5.0 

If your previous arithmetic instruction tried to 
carry (or borrow) beyond bit 1, follow Rule A, 
otherwise follow Rule B. 

JNC 

3 

5.0 

If your previous arithmetic instruction did not try 
to carry (or borrow) beyond bit 7* follow Rule A, 
otherwise follow Rule B. 


Table 2. Program branch instructions. 


Execution time in usee 

Wit ho u t Wit h I nst r uc t i on $ t o t h e m i cr o p r o OS ssor 


Mnemonic 

Bytes 

memory reference 

memory reference 

during execution 

not a 

1 

2,5 

5.0 

Increment the number in register R by one. 

oca a 

1 

2.5 

5.0 

Decrement the number in register R by one. 

IKK R 

t 

2.5 


Register R and the register next to R are to be 
treated as one 16-bit register. Increment that 16-bit 
number by 1. (B, D, and H are the only valid 
registers for 1 his instruction.) 

ocx a 

1 

2.5 


Register R and the register next to R are to be 
treated as one 16-bit register. Decrement that 
16-bit number by 1. (B, D f and H are the only valid 
registers for this instruction. 1 

ADD R 

1 

2.0 

3.5 

Add what you find in register R to what is now in 
the accumulator. Put the answer into the accumu¬ 
lator. Set the carry flag = 1 if there was a carry to a 
bit higher than seven 10-7), Set the carry flag = 0 if 
there was no high bit carry. 

SI'S K 

t 

2.0 

3.5 

Subtract what you find in register R from what is 
now in the accumulator. Put the answer into the 
accumulator. Set the carry flag * 1 if there was a 
bonow attempted from the eighth bit. Set the 
carry flag 3 0 if there was no high order borrow 
attempted. 

SB3 R 

1 

2,0 

3.5 

Subtract what you find in register R (and the value 
of the carry flag) from what is now in the 
accumulator, (The carry flag a 1 might indicate a 
borrow from a previous subtraction.) Then finish 
as if this were a SUB R instruction. 

HLT 

1 

- 

- 

There are no more instructions after this one* Halt 
your execution. 


Table 3. Arithmetic instructions. 
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three bytes. In the interest of 
paper conservation and since 
the assembler program always 
knows how long each instruc¬ 
tion is, let's simply write each 
instruction on one line from 
now on. If you need a 
“refresh" as to how long an 
instruction is, look at the 
column labeled “bytes" in 
the tables. Let's also assume 
our assembler program will 
ignore anything after a semi¬ 
colon. Now, I can write 
comments about each instruc¬ 
tion that will help you follow 
the logic of our programs on 
the same line as the instruc¬ 
tion (or two, if the typesetter 
sees fit). 

Suppose we want to clear 
out more than one byte. We 
could write Program A. 

This would not be a very 
good solution if we really 
wanted to clear a large 
number of memory locations; 
since each instruction takes 
up more than one byte of 
memory, the program would 
be longer than the memory 
we wanted to clear! Branch¬ 
ing instructions can solve this 
problem. They allow us to 
repeat the same instructions 
many times and to make 
compact programs. A branch 
in a program is like a fork in a 
road. The chip will select 
which path to continue on by 
using the condition of the 
flags mentioned earlier (zero, 
negative numbers, carry) to 
make its decision. Study 
Table 2 before you read on. 

Branching instructions give 
a programmer flexibility 
because they can change the 
contents of the program 
counter. Suppose our clearing 
program starts in the first 
byte of external memory, 
that is, at address 000 000. 
See Program B. 

When the third instruction 
is executed, the program 
counter will be changed to 
000 000. This is called a loop, 
since the last instruction 
returns to an earlier instruc¬ 
tion. Of course, this is not the 
world's most useful program. 
It will continue to repeat the 
same instructions until you 
push stop or pull the plug. We 
will have to write a program 


that stops itself after it goes 
through a loop a certain 
number of times. Please eye¬ 
ball Table 3 for further 
instructions. 

Suppose we want to go 
through the loop just five 
times. See Program C. 

Again, we will load this 
program beginning at address 
zero. When execution is 
begun, a five will be placed 
into the C register. The 
second instruction begins at 
memory location 000 002. A 
zero is placed into the accu¬ 
mulator. The third instruc¬ 
tion is at location 000 004. 
The zero is the accumulator is 
sent to address #640. The 
fourth instruction is at loca¬ 
tion 000 007. (Be sure to 
consult the tables if you 
forget how many bytes a 
certain type of instruction 
occupies.) The contents of 
register C is changed to four. 
The next instruction is at 
location 000 010. The pre¬ 
vious arithmetic instruction 
had a result of four. Since 
four is not zero, the next 
instruction will be at location 
000 004, the STA. (I'm 
writing for humans now, not 
for assembler programs. Low 
order bits are last.) Once 
again, the contents of the 
accumulator are sent out to 
memory, and register C is 
decreased by one. When the 
program arrives again at loca¬ 
tion 000 010, the C register 


Program C 


has a three in it Since three is 
not zero, the program jumps 
again to location 000 004. 
This continues until the C 
register is counted down to 
zero. This time, the zero flag 
is set, no jump occurs, and 
the program halts. 

Now we know how to 
control loops. The register C 
is called a counter. We could 
have used any of the available 
registers for this program; 
there is nothing special about 
C. In fact, the 8080 chip can 
use registers as 8* or 16-bit 
counters that can count up or 
down, just by using the 
appropriate instructions. 

However, we still have a 
difficulty with our program. 
Why would we want to zero 
out address #640 five times? 
We probably don't Instead, 
let's clear out five consecutive 
addresses beginning at #640. 
See Program D. 

Don't go past this para¬ 
graph unless you are certain 
you understand this program. 
The first address of this pro¬ 
gram is 000 000. A MV I 
instruction takes up two 
bytes of memory, so the 
address of the second instruc¬ 
tion is 000 002. The third 
instruction is at address 000 
004. The STA instruction is 
at location 000 006. What is 
at address 000 007? Answer: 
One of the two operands of 
the STA instruction, in fact, 
low order bits of the address 


we wish to clear. We put 
these low order bits into the 
accumulator, add one, and 
put them back into address 
000 007. The next time 
through the loop, a zero will 
be sent to address #641. The 
address will be changed each 
time through the loop until 
register C counts down to 
zero and the program halts. 

This program will work. 
We could zero up to #256 
addresses this way. This limit 
is set because we used an 
eight bit register to count 
down. If we used a sixteen bit 
register, we could clear 64K 
of memory; but, since there is 
a possible serious difficulty 
with this method, please read 
on. 

Suppose one day you 
notice that the first two 
instructions of your clear 
program can be replaced with 

LXI B, 005 001 

;Put 1 Into B and 5 into C 

Fantastic. Not only are you 
saving one byte of memory, 
you are also saving 4 micro¬ 
seconds of execution time. So 
you make this change, load 
your new program into 
memory starting at address 
000 000, and execute it 
Everything seems ok. The 
program runs and stops. You 
check memory to make sure 
everything is working prop¬ 
erly and discover only #640 
is clear; the next four address¬ 
es still have data. What went 
wrong? 

Since the beginning of the 
program occupies one less 
byte, every instruction from 
MVI A, 0 and down has 
moved up one address loca¬ 
tion. You forgot to change 
the first operands in the LDA 
and STA instructions from 
007 to 006. Instead of 
changing the low order 
address bits, you were chang¬ 
ing the high order bitsl 

Assembly programs have a 
feature that can save the day 
when such a problem is 
encountered. They will 
accept a name or label 
address instead of numbers. 
Program E lists our repaired 
program showing two exam¬ 
ples of labels: 


MVI A, 

000 


;Put a zero in the accunulacor 



STA 

200 

002 

;Store the contents of A into 0640 


STA 

201 

002 

;Store the contents of A into 0641 


STA 

202 

002 

:Store the contents of A into 0642 


STA 

203 

002 

;DlttO for address 0643 



STA 

204 

002 

;etc. 

_ 


Program A 




MVI A. 

0 


;Put a zero in the accumulator 


STA 

200 

002 

;Store the zero in address 0640 


JMP 

000 

000 

;Jump back to the beginning 


Program B 




MVI C. 

5 


.Put a five into register C 


MVI A. 

0 


,Put a zero into the accumulator 


STA 

200 002 

:Store the contents of the accumulator into 1 




address (>640 


OCR C 



;Dccrcaac the number in register C by one I 

JN2 

004 000 

:lf C is not zero, jump back to the 

STA 

instruction 

HLT 



iStop if C is zero 

_1 


wr 

TT 


Put 1 into register B 

MVI 

c. 

5 

Set up C to count 5 times through the loop 

MVI 

A. 

0 

Put a zero into the accumulator 

STA 


200 002 

0640 In octal 

LDA 


007 000 

Low order bitB first, for assembler programs 

ADD 

B 


Add one to what was in location 7 

STA 


007 000 

Put the answer back into location 7 

DCR 

C 


Decrease the contents of register C by one 

JNZ 


004 000 

If C Is not 2ero, jump back to the third instruction 

HLT 



Stop if C is zero 


Program D 
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LX I 

B. 

005 001 

Put l into B and 5 into C 

LOOP 

XVI 

A. 

0 

Call this address LOOP 


STA 


PLACE 

Store the accumulator in an addrea* called PLACE 


LDA 


006 000 

Put low order bit# of addrea* PLACE into A 


ADD 

B 


Add one 


STA 


006 000 

Change the operand of the 3rd inotruction 


DCR 

C 


;Subtract one from C 


JNZ 


LOOP 

,If C is not zero, jump to the address colled LOOP 


HLT 


iStop after five times throuRh program 

PLACE 

RUB 

5 

;What doeo RMB otond for? 


Program £ 


INR 

B 

B 

- 004, 

L - 

002, 

H - 

001, 

E - 

001, 

A - 

002 

DCX 

H 

B 

- 004, 

L - 

001, 

H - 

001, 

E - 

001, 

001, 

A - 

002 

ADD 

E 

B 

- 004, 

L - 

001, 

001, 

H - 

001, 

E - 

A - 

003 

SUB 

A 

B 

- 004, 

L - 

H - 

001, 

E - 

001, 

A - 

000 


When the assembler pro¬ 
gram reads the second line of 
this program, it knows that 
LOOP is not an instruction. It 
has a table of all the 8080 
instructions and none of 
them are spelled LOOP. So, 
the assembler says to itself, 
"This must be a label. So far, 
I have used up three bytes of 
memory on this program. 
Since I started at address 000 
000, the next address I can 
use is 000 003. From now on, 
whenever I see LOOP, I will 
translate it to mean 000 003 
and remember to put the low 
order bits first." So, the 
assembler program will trans¬ 
late our jump correctly. 

STA PLACE is another 
example of a label. This time, 
the label first appears in the 
program as an operand, 
instead of in front of an 
instruction, so it has to be 
treated differently by the 
assembler program. Addresses 
are only assigned when labels 
are encountered in front of 
instructions, not as operands. 
The address represented by 
the label PLACE is located 
immediately following the 
HLT instruction. The assem¬ 
bler is given this information 
by the pseudoinstruction 
RMB (Reserve Memory 
Bytes). RMB is called a 
pseudoinstruction because it 
is not used at execution time. 
It is only used by the assem¬ 
bly program to assign an 
address location to the label 
PLACE. In our program 
PLACE would be assigned to 
the address 000 024. The 
operand (5) tells the assem¬ 
bler how many address loca¬ 
tions to resen/e. So this pro¬ 
gram will clear the five 
memory locations behind the 
program itself. 

There are still some serious 
objections to this program, it 
is considered dangerous for a 
program to modify itself. For 
example, this program could 


not be run twice without first 
resetting the STA operand 
back to the address represent¬ 
ed by the label PLACE. Each 
time the program has finished 
execution, the STA operand 
has the value of PLACE + 5. 
In addition, this program 
must always be loaded into 
memory beginning at address 
000 000 because of the 
operands of LDA and the 
second STA instructions. 
That means this program is 
not relocatable to another 
section of memory. Finally, 
STA and LDA are very slow 
operations. The total execu¬ 
tion time for our program is 
153 microseconds to clear 
five locations. We can do 
better. 

I've given you a lot of 
information so far and we've 
still got a number of things to 
cover. Following are'some 
more questions and answers 
to help you consolidate the 
previous material. 

Question: A loop occurs 
when a branch instruction 
causes a program to return to 
a previous instruction. Can a 
branch instruction jump to an 
instruction that has not been 
executed? 

Answer: Yes, a branch 
instruction can transfer con¬ 
trol backwards or forwards in 
a program. As long as the 
conditions of the jump are 
satisfied, the instruction 
decoder will change the 
contents of the program 
counter. The contents of the 
program counter is the 
address of the next instruc¬ 
tion. 

Question: Suppose that at 
execution time, the contents 
of register B was 003. We 
could write it this way: B = 
003. Also, suppose L = 002, 
H = 001, E = 001, and A = 
002. What would be their 
contents after each of the 
following instructions was 
executed? 


INR B 
DCX H 
ADD E 
SUB A 

Answer: 


Note that the last instruction 
can be used to clear the accu¬ 
mulator. 

Question: Su ppose you 
assembled, loaded into 
memory, and executed the 
following program: 


HVI 

B, 

007 

MV I 

A. 

A 

001 

AGAIN ADD 


DCR 

B 


JNZ 


AGAIN 

HLT 




How many times would the 
third instruction be exe¬ 
cuted? After this program 
reaches the HLT instruction, 
what would be the contents 
of register B and the accumu¬ 
lator? 

Answer: Register B is 
being used as a counter. All 
of the instructions inside the 
loop that begin at the address 
labeled AGAIN will be exe¬ 
cuted seven times. After the 
HLT statement is reached A = 
#128, B = 0. Notice that 
ADD A will double any 
number that is in A as long as 
it is less than #127. Doubling 
any of the numbers from 
#128 to #255 will cause an 
overflow and not give a 
correct answer. 

Question: Suppose that 
the following three consecu¬ 
tive instructions appear in the 
middle of a program you have 
written. 


MV I A, 

000 

J2 

PUCE 

JMP 

AHEAD 


Will the address of the next 
instruction to be executed be 
PLACE or AHEAD? 

Answer: You don't know. 
Jump instructions use the 
flags to determine if the jump 
should be made or not. Flags 
are set by arithmetic instruc¬ 
tions only. The zero flag was 
given its present value by the 
previous arithmetic instruc¬ 


tion. Since we don't know 
what the last arithmetic 
instruction was, we can't 


predict which jump will be 
made. 

If we rewrite the program 


MV I 

A, 

000 

ADD 

A 


JZ 


PUCE 

JMP 


AHEAD 


The JMP instruction will 
never be executed. ADD A 
will set the zero flag and a 
jump to PLACE will follow. 

Now we can jump ahead 
and write a better PLEASE 
CLEAR MEMORY program. 
In the 8080 chip, the H and L 
register can perform a special 
function. Instead of just using 
internal chip registers, we can 
access external memory by 
using the symbol M in place 
of a register symbol. The 
address of external memory 
that we wish to access must 
be in registers H and L. You 
probably noticed that Tables 
1 and 3 had two different 
execution times for some 
instructions. Whenever exter¬ 
nal memory is referenced by 
H and L, execution time is 
increased. 

We can write a short pro¬ 
gram that will attempt to 
clear all of memory. Let's 
assume our microcomputer 
has 64 K of memory and our 
program starts in location 
000 000. 

Program F will attempt 
to clear itself out of memory! 
Eventually, a zero will be 
placed in address #9 and the 
program will be locked into a 
never ending loop. The 
operand of the JNZ instruc¬ 
tion will be zero instead of 
000 005. Each time through 
the loop, the contents of H 
and L will be reset to 
#65535; thus the program 
will never stop. In fact, the 
HLT instruction has been 
cleared out of memory! 


LX I 

H. 

<365535 

;Put the highest address in H and L 

MV I 

B. 

0 

;Put a zero in roglater B 

LOOP MOV 

M 

B 

2 Send the contents of B to memory 

DCX 

H 


;Decrease 16 bit register H and L 

JNZ 


LOOP 

2 If H and L la not zero, jump to Loop 

HLT 



2 Stop If H and L Is zero 


Program F 
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LX I 

H. 

LOW 

(Address to start clearing memory to H and i 


LXI 

D, 

HXCH 

;Address to stop clearing memory to D and E 
;(Subtract the low 


MOV 

A, 

E 


SUB 

L 


;address from the 


MOV 

MOV 

E 

A. 

A 

D 

(high address in two 
(subtractions. 


SSB 

H 


;The difference la placed in 


MOV 

D, 

A 

(registers D and E) 


MV I 

A. 

0 

(Put a zero in the accumulator 

LOOP 

MOV 

M, 

A 

(Send contents of A to memory 


I NX 

H 


(Increase address for next time 


DCX 

D 


(Decrease 16-blt registers D and E 


JP 


LOOP 

(Zero is a positive number alsol 


HLT 



(Stop when D and E are negative numbers 
;(2 locations each, are needed 

HIGH 

RMB 


2 

LOW 

RKB 


2 

;to save 16-blt addresses) 


Program G 


What we need is a pro¬ 
gram, that can be specified 
just before execution time, to 
clear memory between any 
two locations so that we 
won't have to reassemble the 
program each time we change 
the locations to be cleared. 
The programmer can make 
sure the addresses to be 
cleared do not include the 
program itself. The following 
program is relocatable to any¬ 
where in memory. It only 
requires that the start address 
be loaded into a location 
labeled LOW, and the stop 
address loaded into a location 
labeled HIGH before execu¬ 
tion time. 

Execution time for Pro¬ 
gram G is (13.5 x n) + 25 
microseconds where n is the 

Test Yourself on the 
Above Article 

If a problem gives you any 
trouble, load it into your 
computer and run it. 


MVI 

E. 

5 

MVI 

A, 

0 

BACK ADD 

E 


DCR 

E 


JNZ 

HLT 


BACK 


a) How many times will the 
ADD E instruction be exe¬ 
cuted? 

b) What is in the accumu¬ 
lator after execution? 

c) How could you modify 
this program to put the sum 
of the numbers 1 through 
#10 into A? 



MVI 

E, 

0 


MVI 

B. 

2 


LDA 


NUMBER 


MOV 

D 

A 


ADD 

E 


BACK 

JZ 


STORE 


SUB 

B 



JP 


BACK 


MOV 

A 

D 


STA 


ODD 


JMF 


FINISH 

STORE 

MOV 

A 

D 


STA 


EVEN 

FINISH 

HLT 



NUMBER 

RMB 


1 

EVEN 

RMB 


1 

ODD 

RMB 


_ 


number of locations to be 
cleared. It occupies #30 bytes 
of memory because we must 
count the locations HIGH 
and LOW as part of our pro¬ 
gram. Those locations must 
not be cleared. The program 
is relocatable because we 
didn't specify any locations 
at all when we wrote the 
program. The assembler will 
make address assignments for 
us. The program doesn't even 
specify how many times we 
have to jump to LOOP. This 
is calculated each time we 
execute the program by find¬ 
ing the difference between 
our start and stop address. 
Notice we have also changed 
the type of branch from a 
JNZ to a JP instruction. This 
is because the difference 
between our start and stop 

a) What does this program 
do? You have probably 
noticed how hard it is to 
follow a program that has no 
comments at all. Write com¬ 
ments for each instruction in 
this program. 

b) What happens if “NUM¬ 
BER" has a negative value in 
it? 

c) Modify this program to 
store positive or negative 
numbers correctly. {Hint: 
Instead of subtracting 2 from 
negative numbers, add 2.) 

Answers to Self-Test 
Problems 

1 . 

a) 5 

b) #15 

c) change the first instruction 

*° I MV I E. tflol 

Other solutions are pos¬ 
sible. Try yours on your com¬ 
puter. 

2 . 

a) If a positive number is 
placed in NUMBER, the pro¬ 


addresses is always one less 
than the number of bytes we 
want to clear. If we stopped 
the program when the 
counter reached zero, we 
would not have cleared the 
last memory location. In this 
program, when the counter 
reaches zero, the program re¬ 
cycles cne more time. When 
it returns to the JP instruc¬ 
tion, registers D and E now 
contain negative numbers and 
the program halts. 

Since addresses are 16 bits 
long, and the 8080 chip can 
only do 8 bit arithmetic, the 
subtraction must be done in 
two parts. The first subtrac¬ 
tion will set the carry flag if 
register L is greater than regis¬ 
ter E. The second subtraction 
will continue the borrow if 
necessary, from the previous 

gram will determine if the 
number is odd or even and 
store it in the appropriate 
byte. 

b) All negative numbers will 
be stored in ODD no matter 
whether they are odd or even. 


Program H is presented for 
practice only. If you really 
want to know if a binary 
number is odd or even, just 
look at the least significant 
bit. ■ 


subtraction. If, just before 
execution time, the addresses 
that are stored in HIGH and 
LOW are accidentally re¬ 
versed, registers D and E will 
contain a negative number 
after the second subtraction. 
One byte will be cleared, and 
the program will halt 

This article has introduced 
you to twenty 8080 instruc¬ 
tions. With these, you can 
write a few simple programs. 
That should also be enough 
to give you the confidence to 
attack other instructions in 
the set and begin decoding 
other programs that you find 
in KB and other sources. I've 
included a couple of self-text 
questions (and answers) to 
reinforce your understanding 
of this article. Although, 
expert programmers will 
notice that some of the pro¬ 
grams could have been writ¬ 
ten more compactly, begin¬ 
ning programmers will be 
happy to see, however, that 
I've only used the instruc¬ 
tions introduced in this 
article. 

Welcome to the assembly 
language programming 
world! ■ 


Program H 



MVI E, 

0 

Begin with a zero in register E 


MVI B, 

2 

Ana a two in register B 


LDA 

NUMBER 

Put the unknown msaber into the accumulator 


ADD E 


Add zero to determine sign of number 


JM 

MINUS 

Jump is negative 

BACK 

J2 

STORE 

Zero means you had an even number 


SUB B 


Subtract two 


JP 

BACK 

Jump if remainder is positive 

DONE 

MOV A 

0 

(A negativo number here means 


STA 

ODD 

your original number was odd) 


JMP 

FINISH 

You’re done 

MINUS 

ADD B 



Add two to a negative number 


JZ 

STORE 


Zero means you had an even number 


JM 

MINUS 


Is the remainder still negativo? 


JMP 

DONE 


If not, you started with an odd number 

STORE 

MOV A 

D 


Store your original even number 


STA 

EVEN 


You’re done 

| FINISH HLT 



Halt oxocutlon 

NUMBER RMB 

1 



EVEN 

RMB 

1 



ODD 

RMB 

1 
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6 Digit LED C 

lock Kit -1: 

1124 hr. 

|Q95 QTY-12 
^ea. OR MORE 

41(195 QTY. 
,u ea. 6-11 

41195 QTY. 

1 1 ea. 1-5 


if it i hi r 1 i il rri£ c 6- LED Rcarlouist FIYD-359 Red, com, cathode) 

•Instructions liWiSr 1 ”'' 2 '*’ fl" DIGITS' 

.QUALITY COMPONENTS ORDER KIT#850 4 ’ 

:fS^ISHROPERATS>N AN INCREDIBLE VALUE! 

lUOf^HMU^tHAMUN 24* Molest pins for 1C socket 

"Kit #850-4 wifi furnish a complete set of clock components as listed. 
The only additional items required are a 7*12 VAC transformer, a circuit 
board and a cabinet, if desired. 1 ' 

Printed Circuit Board for kit # 8504 fetched & drived fiberglass I.... $2.95 

Mini - Brito Red LED's (for colon in clock display) pkg. of 5 ....... 1.00 

Molded Plug Transformer 115/10 VAC (with cord)........ 2,50 

MOTE: Entire Clock may be assembled on one PC Board or Board may be cut to remote display. 
Kit #850 4 will fit Plexiglas Cabinet 11. 



CABINET I 

3"H,6%"W,5^''D 

CABINET II 

2)rH,5"W,4''D 

ANYSIZE/COLOR 


$6.50 


PLEXIGLAS 

CABINETS 

Great for Clocks 
or any LED Digital 
project. Clear-Red 
Chassis serves as 
Bezel lo increase 
contrast ofdigital 
displays. 

Black, White or 
Clear Cover 
». 2 /* 12 . 


RED OR GREY PLEXIGLAS FOR DIGITAL BEZELS 

3”x6"x1 IB" 95 c ea. 4/*3 


MOBILE LED CLOCK 

12 OR 24-HOUR OPERATION 
12 VOLT AC or DC POWERED FOR FIXED 
OR MOBILE OPERATION. 

SIX LARGE .4" DIGITS! 

KIT OR ^------MODEL 

ASSEMBLED2001 


i 


Digit-LED Clock-Calendar-Alarm Kit 
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WITH AdjustABLI 
XT At TiWt IIASI 
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• 5 JUMBO ,r RED LED S BEHIND RED FILTER LENS WITH CHROME RIM 

• SLT TIML TROM FRONT VIA HIDDEN SWITCHES - 12/24-Hr, TIME FORMAT 
- STYLISH CHARCOAL GRAY CASE OF MpLDEO HI OH TEMP. PLASTIC 

. BRIDGE POWER INPUT CIRCUITRY - TWO WIRE NO POLARITY HOOK UP 

• OPTIONAL CONNECTION TO 8LANK DISPLAY [Uh Wh*n Kay OH In Car. Efc ,J 

• TOP QUALITY PC BOARDS* COMPONENTS EXCELLENT INSTRUCTIONS 

• WtiuKliHQ 1HACXIT 'HCLUQED 

29*? i£ t $27?? $2?? 


iL*M tv txfWvl 


AS^LMBLID UMTS WIRED * 'ISTOD 

OiDfP *2001 WT (LESS tv BA TTE»Yf 9057* 

*-*10. Up* '} nft <j+ ■* ml 3Tnl**v£i 


1 OR 47791 Uflfl 

MC°[ 90/ J, M.| (M M.»#C VV471 


m Par Giy Pnc» 


^JUMBO RED LED s 12/$1.0Q 50/$3.95 


This is a complete, top of the line. Kit ror the person that wants the 
best. Some of the many features and options are: 12/24 time, 
28-30-31 day calendar, alternates time (8 sec) and date (2 sec) or can 
display time only and date on demand, 24 hr alarm - 10 minute 
snooze, alarm set indicator, 50/60 H2, line operation or use with Xtaf 
time base(#TB-1), built in OSC for battery back-up / AC failure, Aux. 
timer. CHOICE OF DIGITS. 

Kit #70010 6 - -4” Digits $39,95 

Kit #7001C 4 ' -6” Digits & 2-/* (Seconds] S42.95 

Kit #7QG1X 6 * Digits 545.95 

Kits are complete {less cabinet) including PC boards, power supply* 

1C socket, 9 switches, 16 transistors and all parts required for above 
features and options [All #7001 Kits Wilt Fit Cabinet I Above] 


60 HZ. 

XTALTIME BASE KIT 

Will enable Digital Clock or 
Clock'Caf. Kits to operate 
from 12VDC. Uses MM5369 
and 3.5BMHZ, XTAL. Boa 
5-15VOC/2.5MA. 1“x2" PC 
Board. Easy 3 wire hookup 
Accuracy: +- 2 PPM 

#TS-1 [adjustable] 
Complete kit $4.95 ea 
Wired & Cal. $9.95 ea 
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DTL 
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74S151 196 
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74S1B3 l 06 
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* 36 
40 
56 
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56 
50 
46 
46 
46 
56 
M 
U 
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m 
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to 
% 
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1 40 
96 
96 
75 
.76 
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LED DRIVERS 
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7+*a 
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95 
M 
66 
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REGULATORS 
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LM 30$ K TO-3 t-to 


7806 
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m 
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TO-3 
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TO 5 

TO-3 

OlP 

TO~5 
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,75 
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.75 

-75 
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DIODES 
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DUAL TIMER 
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Ml, 00 
to 
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PINS 
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a 

1 .to 

4.22 
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14 

.25 

22 
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16 

26 
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16 
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,28 

26 
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to 

00 

M 
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MEMORY 
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KR2S60 

HR 2567 
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TRANSISTORS 
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TO 92 5/91jOO 
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SWITCHES 
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TRANSISTOR SOCKET 
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NYLON WIRE TIES 
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50 13,to 
100/17 50 
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sue Turn 
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OPTOELECTRONICS, inc. 

BOX 219 • HOLLYWOOD, FLA, 33022 • (305) 921-2056 


PRINTED CIRCUIT BOARDSfor CT-70Q1 Kite sold 
separately with assembly info. PC Boards are drilled 
Fiberglass, so I dor plated and screened with component 
layout. Specify for #7G01B or 70Q1C (Set of 2} $7,95 


JUMBO DIGIT CLOCK KIT 

A complete Kit (less Cabinet} featuring: six ,5' r digits, 
MMS314IC, 12,24 Hr. time, 50/60 HZ,, PJug^Transformer, 
Line Cord, Switches, and all Parts. 

(Ideal Fit in Cabinet ||] * 1Q 9 ^ 27*38 

Kit 45314-5. ...... ca 


JUMBO DIGIT CONVERSION KIT 

Convert small dlgfl LED clock lo large .5" displays Kit 
includes 6-.S’ 1 LED's,Multiples PC Board & easy hook-up Info. 

KII M JD-ICC For common Calhode 
Kll * JD-1CA For common Anode 


*9” 2/M9. 


Fairchild Super Digit 
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i 


.4" OkW, Hi 
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Over The years Pete Stark has written several books on computers and computer programming (one of which we offer through 
the Kilobaud books section), plus a number of magazine articles on computers and digital devices, A longstanding contributor to 
73 Magazine, Pete wrote an article on the construction of a digital counter several years ago which became one of the most 
popular construction projects in the entire country. In 1967 {which is ancient history in this game), Pete wrote an article for 
Electronics World in which he described interfacing a /Worse code keyer to a POP 8$ computer he was teaching with , The 
following excerpt from that article reveals quite a bit about bis insight and vision regarding the "home computer" (remember . ., 
19671 

"The price of $10,000 for a mere automatic keyer may seem somewhat steep f even considering its features. But remember 
that it can also do other things. In its spare time , the computer can balance your checkbook, do the kids' homework, or play 
tic tac-toe with your neighbor. During a dull party it makes an excellent conversation piece; it can even be taught to tell your 
guests things you would never dare tell them yourself!" 

"Programming? It's simple!" not only presents the beginning programmer with an interesting (and practical) method of 
getting into programming . *. it also has a couple of neat application programs at the end. If we can collect enough such 
programs, we wiit reprint them as a book. Everyone who contributes an accepted program will not only get paid for the write-up 
but also receive a free copy of the book. Send 'em inI - John. 


Programming? 
It’s Simple! 


Peter A Stark 

PO Box 209 

Mt. Kisco NY 10549 



I n case you hadn't noticed, 
there's a revolution going 
in personal computing. Years 
ago only a very large corpora¬ 
tion (or government) could 
afford a computer; now there 
are thousands of computer 
hobbyists who have their very 
own personal computers 
purring away happily in their 
basements* 

Even more people are 
i nterested in these small 
computers but are scared 
away by the prospect of 
having to program them. 
When you build or buy a 
computer, that's only half the 
job. In order to use it, you 
have to give it programs the 
instructions that toll it what 


to do and when* And the 
common feeling is that pro¬ 
gramming must be very hard 
— after all, professional 
programmers can get upwards 
of $20,000 a year for doing 
it, so it must be hard - right? 

Wrong! Once you get the 
hang of it, programming is a 
cinch. And it's great fun. 
When I first learned to pro¬ 
gram a real computer, 1 spent 
nights at the office program¬ 
ming and running the 
computer just for the sheer 
fun of it — on my own time. 
Now that l teach program¬ 
ming, l find many students 
whom I literally have to push 
out the door of the computer 
room at night when we close, 
I may have trouble getting a 


half page of homework out of 
them, but put them into the 
computer room and they 
don't want to go home* It's 
addictive* 

In this article, 1 will try to 
introduce you to program¬ 
ming in a new way. And best 
of all, I will show you how, 
for less than S80, you can get 
your own "programming 
machine" to practice on and 
see whether you like pro¬ 
gramming well enough to get 
your own full-scale computer 
system going, Once you get 
your feet wet, 1 bet you 
won't l>e able to resist going 
deeper into computing. What 
I am going to do is to 
describe how to program one 
of the new programmable 


calculators and show you 
how this is similar to pro¬ 
gramming a real computer. 

Programmable calculators 
are available from several 
manufacturers, including 
Hewlett-Packard, Texas 
Instruments, Novus (National 
Semiconductor}, and Sinclair. 
The ones made by HP and Tl 
are the best known of these 
The H-P models range in price 
from about SI 25 up to 
several thousand dollars* The 
models of interest to the 
average individual, however, 
a re m the ra nge of a bout 
SI25 to about $400. These 
include the HP-25 ($125) 
which can run fairly nice 
programs, but as soon as it is 
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turned off it forgets the pro¬ 
gram you have entered; if you 
want to run it again, you 
must key the program in 
again. The HP-25C {about 
$175) is identical, but has a 
CMOS memory which 
remains powered even with 
the power switch off. As a 
result it remembers programs 
and data even when turned 
off. The HP-67 (about $400) 
is substantially more power¬ 
ful and has the added capa¬ 
bility of storing and saving 
programs on small magnetic 
cards. With a stack of mag¬ 
netic cards you can build up a 
library of progams and feed 
them back at any time. 

The Tl models are roughly 
comparable. The SR-56 
model (about $80) is about as 
complex as the HP-25, while 
the SR-52 (about $200) has a 
magnetic card like the HP-67. 
Novus, Sinclair, and others 
have several much less sophis¬ 
ticated models in the 
$80-and-under range. For a 
n o n m athematical begi nner, 
the Tl units are simplest to 
use, so I will describe pro¬ 
gramming with them in mind 
Wtiile the $200 SR-52 is more 
powerful, can run longer 
programs, and has the mag¬ 
netic card which greatly 
simplifies use, the SR-56 at 
$80 (at the time of writing — 
by the time you read this it 
may be even less expensive) is 
perfectly adequate to explore 
programming and we will use 
this as our example. 

As we talk about program¬ 
ming this calculator, we will 
use some of the words 
normally reserved only for 
the big computers. In this 
way you will learn some 
computer lingo. Whenever we 
introduce a new word it will 
be italicized , like this. Keep 
in mind also, that all numeri¬ 
cal values will be given in 
decimal (like 5, 19 or 

78.325), rather than in the 
binary numbers normally 
used by computers. This will 
help you master the funda¬ 
mentals of programming 
without getting bogged down 
in irrelevancies. So, here goes. 

First of all, a program¬ 
mable calculator has a display 


like that of a regular calcu¬ 
lator. This display shows the 
numbers the calculator is 
using. A computer usually has 
a control panel on which 
there are rows of lights which 
also indicate the numbers 
being worked on The differ¬ 
ence is that on the calculator 
the display is the only output 
device, whereas a computer 
may have additional output 
devices such as a printer or 
tape punch. The readout 
display on a computer's 
control panel is generally 
used only rarely, whereas on 
the calculator it is used all the 
time. 

Internally, the display is 
connected to a display regis¬ 
ter. The word register gen¬ 
erally refers to a group of 
flip-flops which actually 
holds the number, while the 
display only indicates the 
contents of that register. In 
computer lingo, this register 
would be called something 
like accumulator, accumula¬ 
tor register, AC register, or 
perhaps just A register . 
Simple arithmetic such as 
addition or subtraction is 
done in this register, which is 
frequently just a temporary 
stopping place for numbers 
on their way from one place 
in the computer to another. 

In addition to the accumu¬ 
lator register, programmable 
calculators and computers 
often have other registers 
which are used for temporary 
storage of numbers. In some 
machines they can be used 
only for such storage, while 
on other machines they may 
be able to do very simple 
operations such as addition. 
These are called auxiliary 
registers and are labeled with 
numbers or letters. In the 
8008 microprocessor, for 
example, these registers are 
labeled A, B, C, D, E, L and 
H. The SR-56 has ten such 
registers, labeled Register 0 
through Register 9. (Notice 
how the numbers range from 
0 through 9; not 1 through 
10. This is common in 
computers, and it brings up 
an old joke — How do you 
tell whether a person is a 


programmer or not? Ask him 
to count to five. If he starts 
with zero, he is; if he starts 
with 1, he's not.) 

Programmable calculators 
and computers also have a 
memory . This memory is 
used to store program instruc¬ 
tions, data to be used in the 
program, as well as results of 
calculations. (This is the one 
big drawback to program¬ 
mable calculators: Their 
memory can be used to store 
only programs and data to be 
worked on — never results. 
Results can go only into regis¬ 
ters.) 

On the SR-56 calculator 
the memory is divided into 
100 separate locations, each 
with its own address. On the 
SR-56, these addresses range 
from 00 to 99 (Notice that 
again we start with 0, not 
with 1). If we use this mem¬ 
ory only for program instruc¬ 
tions, then we can put in up 
to 100 instructions; on the 
other hand, if we use part of 
it for data to be used in 
calculations, there will be 
room for fewer instructions. 
In most cases we are limited 
to much shorter programs 
both because part of the 
memory is needed for data 
(and results in real-life com¬ 
puters) and because some 
instructions require more 
than one memory location. 

Each calculator memory 
location provides room for 
the storage of a simple 
number. In the case of the 
SR-56, each location can 
store a two-digit number such 
as 02 or 95. For example, 
memory location 00 might 
have stored in it the number 
33, while location 01 might 
hold the number 21, and so 
on. The contents of a memory 
location is called a word in 
computerese. Since each 
word is two digits long, we 
say that the word length is 
two digits and that this is a 
fixed word length memory. 
In this case, we are measuring 
word length in decimal digits; 
in computers we use 6/nary 
digits (or bits), and so we talk 
about 8-bit word lengths and 
so on. Obviously the greater 
the word length, the more 


information you can store in 
each memory location. The 
programmable calculator is 
hampered by its very short 
word length and thus results 
of calculations cannot be 
stored in their main memory 

— there is just not enough 
room! Only the display and 
auxiliary registers are long 
enough (13-digit word length) 
to store big numbers. 

Let's now jump ahead a 
bit and consider an actual 
program. Suppose we have a 
number stored in Register 1 
which we wish to add to 
another number stored in 
Register 3, with the answer to 
be left in the display register. 
An actual program to do this 
would go something like this: 

Kusber in Reglscar 1 
Add 

Number In Register 3 

- (Leave answer in display register.) 
STOP 

Since this "program" is 
written in English, it now 
must be translated into key¬ 
strokes on the keyboard, so 
that it can be stored in the 
calculator's memory. After 
examining the keys on the 
keyboard and reading the 
instruction book, we find 
that: One key is labeled RCL 
(Recall - which means get a 
number from a register); 
while there is no key labeled 
Add, there is one with a + 
sign; and finally there is a key 
labeled R/S, which stands for 
RUN/STOP. Using these 
keys, the program becomes 

RCL 1 

+ 

RCL 3 

R/S 

This is a program written 
using symbols. In computer 
lingo, we would say that it is 
written in symbolic code 
(often called assembly lan¬ 
guage, because it is then used 
by something called an 
assembler ). A program 
written in such a language is 
simply a description of what 
we want done, cut up into 
little chunks small enough for 
the computer (or calculator) 
to handle one at a time. We 
simply have to memorize 
which symbols the computer 
or calculator will accept 
(learn a new language), and 
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Fig. 1. 
Simple 
flowchart 


then use them properly On a 
computer, all these symbols 
consist of letters (such as 
ADD, SUB, STOP, etc.), on 
calculators they may consist 
of letters or characters like +, 
•, or-r . 

If you have been reading 
all this carefully so far, you 
probably have a question or 
two. We said a short time ago 
that this program must be 
stored in the calculator's 
memory. But we also said 
that each memory location 
can only store a two-digit 
number. How then do we 
store something like RCL 1 
or " ="? The answer is 
simple — every time we press 
a key on the keyboard, the 
key generates a two-digit 
number. The RCL key is 
three keys down from the top 
and four keys in from the 
left, and so it is wired up to 
generate the number 34. The 
" = " key is in the ninth row 
from the top, four keys over. 



Fig. 3. Flowchart for count¬ 
ing to 10.{ 



Fig . 2. 

Flowchart for 
counting 1, 2, 
3 


and so it generates the code 
94. The digit keys are treated 
a bit differently - the 1 
translates into a code 01, and 
the 3 into 03. As soon as we 
press each key, the symbolic 
code gets translated into a 
numeric code: _ 


Symbolic 

Numeric 

RCL 1 

34 01 

+ 

84 

RCL 3 

34 03 

• 

94 

R/S 

41 1 


The numeric code, when used 
with computers, is actually 
called machine language . For 
each symbol in symbolic 
(assembly) language, there is 
a different numeric code. On 
a calculator, the translation is 
automatically done by the 
keyboard and associated 
circuits; in a computer the 
translation from assembly 
language to machine language 
is done by a program called 
an assembler , which uses a 
different procedure. Since 
different brands or models of 
calculators have different 
keys in different positions, 
they would have not only 
different symbolic languages 
but different machine lan¬ 
guages as well The same 
applies to computers — learn¬ 
ing to program one computer 
can teach us the basics of 
programming, but whenever 
we switch to a different 
model we have to look up the 
new codes (symbolic and 
machine) we need for that 
machine. When the very first 
computers were made, they 
were programmed entirely in 
machine language. Then, 
somewhere along the way, 
assemblers were invented and 
programmers switched to 
using assembly language. (The 


assembler is a fairly complex 
program which does the 
translation. Very small 
computers which do not have 
sufficient memory to run an 
assembler are therefore still 
programmed in machine 
language.) An even later 
development is a super¬ 
assembler called a compiler 
which can translate more 
useful and more easily 
learned languages, such as 
FORTRAN or BASIC, into 
machine language. But, since 
such a compiler uses even 
more memory than a ordin¬ 
ary assembler, you must 
already have a fairly large 
computer to be able to use it. 
Relatively few personal 
computers are big enough to 
run a FORTRAN or BASIC 
compiler. But enough of this 
detour — back to machine 
language. 

We note that some instruc¬ 
tions, like the R/S or stop 
instruction, were translated 
into a single number, like 41. 
This instruction is a very 
simple one and only consists 
of the instruction or opera * 
tion code 41. On the other 
hand, the RCL 1 instruction 
was translated into 34 01. 
Obviously, the 34 stands for 
RCL, while the 01 specified 
which register. In this case 
the instruction consists of 
two parts - the operation 
code 34 and an operand 01. 
The operand specifies where 
or to what the operation 
applies. 

If the calculator had a long 
enough word length, both 
parts of the RCL 1 instruc¬ 
tion could be stored in the 
same memory location. In 
that case, each instruction 
would be stored in one 
memory location. Whenever a 
computer or calculator has a 
short word length, however, 
some instructions are too 
long to fit into one location. 
Depending on the type of 
instruction, we may have one 
word, two word, or even 
three word instructions 
mixed in the same program. 
This is one of the great dif¬ 
ferences between big com¬ 
puters and little ones — large 
computers tend to have long 


word lengths, and so rela¬ 
tively few words may be 
needed to make a reasonable 
program. Small computers 
on the other hand, usually 
have short word lengths, thus 
many words are required to 
produce the same program. 
For example, 8-bit micro¬ 
computers have 8-bit words, 
thus many of their instruc¬ 
tions require two or three 
words. Likewise, the SR-56 
has two and three word 
instructions, and so its 
ICO-word memory limits us 
to programs of only a few 
dozen stops. 

Let us now take the above 
program and actually put it 
into the SR-56 memory. 
Before putting it into mem¬ 
ory, however, we must decide 
where in memory we shall 
put it. The usual convention 
is to pick a starting address 
and then put successive 
instructions into the follow¬ 
ing addresses. An easy choice 
is to start the program at 
location 00: 


Memory 

Memory 

Addrati 

Content! 

00 

34 

01 

01 

02 

64 

03 

34 

04 

03 

05 

94 

06 

41 


A total of seven memory 
locations is needed for this 
program, out of the 100 loca¬ 
tions available. (Note: The 
SR-52, 224-word memory 
permits longer programs. 

Although the program's 
instructions are in some cases 
spread out over two (or even 
three) words, the calculator 
knows how many locations 
go with each operation code, 
and so it will perform the 
program properly. You may 
wonder why we needed the 
stop code 41 at the end of 
the program. Since the overall 
memory contains 100 loca¬ 
tions, the other 93 unused 
locations might still have 
some other numbers in them 
from a previous use. If we did 
not put in the stop 41, the 
calculator would continue 
running past steps 05 and 06 
into step 07, at which time it 
would probably start doing 
something else. It might never 
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stop, or it might output some 
really strange results. 

Knowing how theprogram 
is stored, now allows us to go 
back and rewrite it in sym- 


This is the form in which we 
would usually write a pro¬ 
gram for the calculator. We 
would use the symbolic code 
and let the calculator do its 
own conversion. Note espe¬ 
cially the comments column 
— when you return to the 
program a day or a month 
later, good notes help a lot to 
remind you of what you were 
doing. 

Another device which 
helps you to document a 
program and even to design it 
in the first place, is a flow¬ 
chart This is simply a map of 
the program which describes 
the order in which things get 
done. Fig. 1 is the flowchart 
of this simple program. Note 
that the shapes of the blocks 
differ, depending on what 
instruction is being carried 
out. In this particular case, 
the flowchart is so simple 
that it is almost a waste of 
time to write \t This is 
seldom the case. Often, there 
arc bops in a program — 
repetitions of certain parts of 
program over and over. Fig. 2 
shows the flowchart of a 


program which flashes the 
numbers V, 2, 3, 4, 5 ... on 
the display. This program is a 
loop, which starts with a zero 
(which we have previously 
put into register 1), adds to it 
a 1 (which we have previously 
put into register 2), puts the 
answer (1) into the display, 
and pauses for a moment to 
let us read it Then it goes 
back to add another t. This 
program will repeat the loop 
until we turn the calculator 


off, each time increasing the 
number in the display by one 
and displaying the result To 
write this program we need 
two new instruction codes: 


program to pause for about Y* 
second before continuing; 
and GOTO, which causes the 
program to go to a different 
memory location for its next 
stop. If you remember our 
previous program, we started 
the program at location 00 
and placed each successive 
part of the program into the 
next location. Thus the calcu¬ 
lator (or computer} would 
normally start at 00, go to 
01, then 02, and so on. The 
GOTO instruction breaks that 
sequence causing the program 
to take its next instruction 
from a different location. A 
simplified program to do the 
job outlined in Fig. 2 would 
be something like: 

rcu 

RCL2\ 

FALSE ) 

Assigning each part of this to 
a memory location, we note 
that PAUSE is a one-word 
instruction, while GOTO is a 
3 word instruction. The pro¬ 
gram as actually entered into 
the machine is program B. 


See why the GOTO is a 
three-word instruction? The 
next two words give the place 
to GO TO — in this case 
location 02, which is the loca¬ 
tion of the add instruction. 

The above program is a 
good example of a loop, but 
it has the disadvantage that 
there is no way to get out of 
the loop. It will continue 
until you manually stop the 
calculator. In most cases you 
will wish to provide a built-in 


bolic terms (see 

program A). PAUSE, which 

causes the 

LOCAUQM 

CODE 

COMMENTS 


00 

01 

02 

KCL 

l 

+ 

Recall register l. 


Add concents of register 3. 

Program (A) 

03 

04 

OS 

rcl 

] 

Leave: the sus In display. 


06 

R/S 

Stop, 



location 

CODE 

COMMENTS 


00 

act 

Cet a 0 fros register I. 


01 

I 


02 

+ 

Add a 1 froa register 2, 


03 

KCL 



04 

05 

2 

Leave answer ir. display. 

Program IB) 

06 

FALSE 

Pause \ second. 


1 0? 

GOTO 



OS 

0 

Co back to step 02 to 4dd again. 


OS 

2 




Fig . 4. Flowchart for computing weekly salary , 


stop. Loops are usually 
performed for a fixed number 
of repetitions or until they 
provide a desired result. This 
is done by means of condi¬ 
tional GOTO instructions, 
which do a GOTO only if a 
certain condition is satisfied. 
The conditional GOTO rests 
some internal condition each 
time the loop occurs. In the 
case of the SR-56, there are 
several test instructions we 
could use, along with an extra 
register called a T (or Test) 
register. Let us modify the 
flowchart of Fig. 2 to count 
only up to 10 (see Fig, 3), 
This chart is similar to that of 
Fig. 2, but with important 
differences — near the top, 
we initialize the T register to 
contain the number 10, and 
later we compare the con¬ 
tents of the display register 
with the T register. If they 
are the same we stop; if they 
are different we go back to 
add another 1. 


The flowchart is fairly 
easy to decipher if you start 
at the top and follow the 
arrows (making believe that 
you are the computer or 
calculator as you go along). 
Initially, we start with the 
display at 0, add 1, then 
pause with the number 1 
showing. Then we check 
whether the 1 is the same as 
the 10 in the T register; since 
it isn't, we go back to add 
another 1, and next display a 
2. We keep going around the 
loop like this until we display 
a 10, after which the 
diamond-shaped decision 
block shows us that we need 
to go to a stop. 

In programming this 
problem, we need two more 
operation codes: X*T moves 
the number from the display 
register {called x on the 
SR-56) into the T register. 
ir X-T?' J checks whether they 
are the same, * J X-T?" is 
actually a conditional GOTO 
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which does a GOTO if the 
condition is satisfied; it is a 
three-word instruction on the 
SR-56. (The complete pro¬ 
gram is shown in program C.) 


used for jobs other than loops. 
For example, the conditional 
"X > T?" (is X greater than 
T?) would be used to make 
the decision in the overtime 
portion of the flowchart 
shown in Fig. 4. This program 
takes the number of hours a 
person works, together with 
the hourly rate, and com¬ 
putes the weekly salary 
(before deductions). If less 
than forty hours are worked 
(checked by the diamond 


shaped box) the program goes 
to the left and the result is 
simply the number of hours 
times the hourly rate. 

If more than forty hours 


at the test box is a YES. As a 
result, the program computes 
straight pay for the first forty 
hours and then adds time and 
a half for overtime pay for 
the hours over forty. 

From some of the demon¬ 
stration programs you have 
seen that really useful pro¬ 
grams may take quite a few 
program steps. For this 
reason computers tend to 
have fairly sophisticated 
operation codes whose 


LOCATION 

CODE 

comments Program (Cl 

00 

RCL 

Get a 10 from register 3 

01 

3 

02 

X-T 

and put It into T register. 

03 

04 

05 

RCL 

Get a 0 froa register 1. 

+ 

Add a l from register 2. 

06 

RCL 

07 

2 


08 

- 

Place answer in display. 

09 

PAUSE 

Pause % second. 

10 

X-T? 

> 

11 

1 

>If X-T GOTO location 16 to stop. 

12 

6 

13 

GOTO 


14 

0 

)otherwise go back to step 05. 

15 

5 

16 

R/S 

Stop. 


Conditional GOTOs can be are worked, then the answer 
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KEY 

COMMENTS 

00 

i4 

“Hu. 

Vcc 

01 

U4 

4 


02 

64 

X 

X 

03 

34 

HO. 

TO - 

04 

01 

1 

02 

OS 

54 



00 

52 

( 


07 

34 

RCL 


qa 

00 

0 

TH1+R2) 

00 

64 

+ 


to 

34 

"fed. 


11 
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REGISTERS 


nr 

_R1_ 

n R2 —— 

7 

RC 


RE 

4 

Vcc 

_5_ 

_JE_ 


NOTES 

Test cnoe: if 

f Rl 

- 6BOOO 

rar 


RC 

- 4700 

RE 

» 1000 

~Vcc~ 

- 12V 

VB 

then 

- i.5m r 

VE 


IE 

- '.&38ma 

VC 

- 6.059V 

Gain - 157.6 i 


Program for finding base, emitter, and collector voltages , 
emitter current, and gain for the amplifier in Fig. 5. 


VCC« *I2V 



purpose is to do a lot with 
just one instruction. Each of 
the examples we have done so 
far could have been made 
shorter had we used some of 
the more complex instruction 
codes available. In addition to 
the simple operation codes 
we have touched on so far, 
the SR-56 includes many 
more. Some of these are more 
powerful than those of many 
large computers - for 
instance, the SR-56 can find 
square roots, sines, or logs in 
only one step, while actual 
computers generally need 
long programs to perform 
these same tasks. Thus even 
the 100-location memory of 
the SR-56 can be used to run 
quite useful programs. 

For example, Fig. 5 shows 
a simple common-emitter 
amplifier. Given the values of 
the resistors and a few simple 
assumptions (such as that the 
transistor has a fairly good 
beta or that the emitter resis¬ 
tor is not too small), it is easy 
to calculate the voltages, 
currents and the gain. Fig. 6 

shows the SR-56 program 

which does just that. Aside 

from a few new operation 
codes, such as STO which 

stores a number into an auxil¬ 
iary register, this program 
demonstrates another com¬ 
puter trick. 


Whenever a program needs 
a simple constant, such as 0.7 
or 0.025, this constant could 
be stored in a register (or in a 
memory location of a large 
computer) and then recalled 
with an RCL instruction. But, 
if the constant is used only 
once in the entire program, 
this wastes a register which 
might be needed for some¬ 
thing else. Instead, it is pos¬ 
sible to put this constant 
directly into the program as 
shown in steps 16-17 or 
42-45. In computers this is 
done by means of immediate 
instructions. For example, 
the 8008 microprocessor can 
load a number into the A 
register from memory by 
means of a LAM (load A 
from memory) instruction. 
But to do so requires that we 
also provide an address which 
goes with the instruction and 
tells the computer where to 
get the data to be loaded. It is 
much easier to use a LAI 
(load A immediate) instruc¬ 
tion, and then put the 
number to be loaded into the 
very next location in memory 
after the LAI. We still have to 
put the number somewhere, 
but we avoid all the problems 
of addressing it. In a program¬ 
mable calculator, this trick 
avoids the use of another 
register. ■ 



from page 67 

I am sure that this one will be a 
thousand times better than the last. 
Although I still have my subscription 
to the original Byte and have gained 
from it, your new mag should offer 
even more for all us starters in the 
digital race. 

I have enjoyed the I/O sections 
each month and will be looking 
forward to receiving KILOBAUD in 
the future. Thanks for having another 


go at it and helping the hobby now 
with your great publications. 

By the way, the tear*out “bingo” 
card system this month is really 
handy. I have been wanting to 
mention it but have forgotten it every 
time 1 wrote. The one in Byte is tough 
to use and makes it hard to be sure 
that you are getting information 
wanted. I always have to look at its 
advertiser index, then look up the ad 
in the magazine. This takes a lot of 
extra time. On the other hand inter¬ 
face puts its card numbers right under 
each ad. With this, I can make a quick 
pass through the mag when it arrives, 
check off any interesting items, and 
then go back through and study the 
rest of the material. Yours seems to be 


a cross between these two ideas and 
works pretty well, but you might take 
a closer look at something like that 
used by Interface (although this might 
be much more difficult to print). 
Anyway what you’ve done is a change 
for the better. Thanks again. 

Pat Snyder WA0TTW 
RR-3 Fremont NE 68025 


EDP/Center — Desk or Phone? 


I retired from my firm in 1969 and 
have been doing business counseling 
for international clients since then. 
Almost all of my clients were stalled 
with an EDP system they didn’t 


understand or, what is most remark¬ 
able, refused to use. Generally the 
problem has been that the accounting 
department controlled the system and 
attempted to keep figures a secret, 
except for a very few executives. 

In my own business (retail), I devel* 
oped over the years a software system 
that used only a pencil and a small 
hand calculator. With this system (we 
grossed about $1 M per month), I was 
able to predict the final operating 
costs and net profit on a daily basis. 
Our monthly Profit & Loss came out 
ten days after close of the month. In 
the retail business this is too late! 

I am interested in any new develop- 

continued on page It 6 
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CALL TOLL FREE 800-521-4414 

MOBILE DIGITAL 

CLOCK 


AVAILABLE NOW - 
In-Dash 
On-Dash 
Black/Chrome 
Brown/Chrome 


ENLARGED 
TO SHOW 
DETAIL 



The DC101A digital clock sets the trend in digital automotive electronics which will be offered in 
the upcoming years. Its small size (1% x 2% x 5/8) and coordinated leather texture and chrome 
exterior make it an attractive addition to any car. Solid state electronics and a quartz crystal 
produce a clock that is the most modern timekeeping device for automobiles. It can be easily 
mounted in minutes in its compact ABS plastic case. Installation is accomplished by drilling an 
eighth inch hole in the dash, passing the power wires through it, and connecting them to the 
power with quick-connect wire clamps. Bright light emitting diodes (LED) allow for easy reading 
in all conditions. Since the clock is all solid state, it is inherently long life. A one year guarantee is 
offered on the clock. 


\ Quartz Crystal Accuracy 
• Light Emitting Diodes 
\ AH Solid State Electronics 
i Unit is Protected by Fusistor 


Black or Brown Case 
< Installs in Minutes 
> One Minute/Month Accuracy 
i One Year Guarantee 


LIST 

PRICE 


INTRODUCTORY 

PRICE 


Toll free U.S.A. 24 hour order & information tine 800-521-4414, Outside U.S.A. & Michigan 24 
hour phone 313-994-4441. Certified check or charge card on mail orders for immediate 
shipment. Dealer inquiries invited. Michigan residents add tax. Foreign orders invited. Call toll 
free or write for your free complete catalog & specifications. Satisfaction guaranteed or your 
money back. For engineering advice, call after 6:00 PM EST. 


rA 

master charge] 

THE INTERBANK CARO 




COMMUNICATIONS ELECTRONICS 
P.O. Box 1002 Dept. 5 
Ann Arbor, Michigan 48106 


BankAmericaro 




Structured Programming 


... order 


out of chaos? 


Okay . Bill Jones has provided us with some of the ground rules with which to carry on. His 
article on structured programming is of a straight tutorial nature, which is something we 
normally don't get too turned on about here at Kilobaud (not that there's anything wrong 
with his article ... it's just that we prefer to have a subject discussed using an example we can 
all relate to). Which brings me to my point: / would like very much for some of you software 
types who believe so strongly in structured programming (which is not to say / don't, for 
heaven's sake!) to get busy and run some comparisons. If we're going to "sell" the hobbyist 
programmer on these techniques then let's come up with some examples which clearly 
demonstrate the advantages of the new over the old. Then, write it all up into a fully-edited 
article, complete with diagrams, photos, and bells and whistles. Next step, of course, will be to 
send it to me so we can share it with the rest of the world (and make some bucks for you in the 
progress). - John. 

Entry Point. Used to signify entry from another 
program. May contain the name of the particular 
program, routine or subroutine and always con¬ 
tains an entry point label. 



Processing Block. Describes a function being per¬ 
formed within the logic flow. 


Decision Block. Describes a function decision and 
indicates a two way branch. 



Bill Jones 
541 Easy St 
Marion OH 43302 


Multiple Branch. Used as a functional branch 
where multiple decisions are possible or where 
multiple decisions are processed. 


Connector. Denotes an entry point within a pro¬ 
gram segment or an entry from a different flow¬ 
chart page. Contains a label used as an entry point 
or a number for continuation purposes. 



Exit. Points to another program sequence or to 
another flowchart page. Contains an entry point 
label ora continuation number. 



Label Block. Contains system and/or program 
defined labels when used in flowcharting. 

Comment. Used when additional comments con¬ 
cerning a particular function are needed. 


Fig. 1. Flowchart Symbols 
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I n the past, design of soft' 
ware followed no particu¬ 
lar design criteria which took 
reliability into account, and 
hence it was left to the indi¬ 
vidual to produce reliable 
code. While this has not been 
bad, it has not always pro¬ 
duced reliable software. This 
is to say that the programs 
produced are not always 
correct. Many hours of test¬ 
ing go into an attempt to 
prove correctness after the 
design effort The following 
guidelines are intended to 
ensure that any program 
designed using them will be 
correct white that program is 
still in the state of being 
designed and coded. Un¬ 
doubtedly situations will 
come up in which it can be 
argued that the guidelines 
established are too restrictive, 
inefficient, or don't apply to 
the program under develop¬ 
ment; but at least these guide* 
lines provide a common 
starting point which all can 
understand. (Needless to say, 
these guidelines apply to the 
personal systems programmer 
as welt as any other.) 

The program development 
design guidelines are taken 
from what is known in the 
literature as structured 
programming. Structured pro¬ 
gramming is based upon 
controlling the processes of 
program generation. These 
processes break program 
composition down into rules 
which are easily understood 
and establish "correctness" of 
design. 


Control Structures 

The control structures are 
given as the following se¬ 
quence. The code for the 
flowchart symbols is shown 
in Fig. t. 

Simple Sequence . A simple 
sequence is one which per¬ 
forms a single function, 
operation or process. It 
makes no decisions. The flow 
of control is not relinquished 
within the operation. Control 
is given to the process and 
must return from the process. 
Mathematically it is linear 
reasoning. Symbolically, we 
represent this sequence as 
shown in Fig. 2. 

, T , 


"T" 

Fig. 2. 


D e c isi o n Sequence. A 
decision sequence allows the 
result of a test to select the 
next executable statement. It 
is basically the IF-THEN- 
ELSE construct. While the 
decision is often a true or 
false answer it need not be. 
The decision could logically 
be a multiple decision tree. 
The flow of control is 
allowed to follow different 
paths within the sequence. 
However, when control is 
relinquished to the decision 
sequence, only one point of 
return from the processes 
within is allowed. Control is 
given to the decision se¬ 
quence and then returned. 
The decision sequence is 
shown in Fig. 3. 

Conditional Sequence. The 
conditional sequence allows 
the logical DO-WHILE con¬ 
struct. It allows several itera¬ 
tions of a process until a 
condition is met. Control 
from the sequence is not 
allowed to go on to the next 
executable statement until a 
decision is reached which 
allows it to continue. The 
conditional sequence is illus¬ 
trated in Fig. 4. 


GeneraI Conditional Se¬ 
quence. An additional se¬ 
quence, the general condi¬ 
tional sequence, is not much 
different than the conditional 
sequence but probably has 
more practical value. The 
sequence combines the condi¬ 
tional and simple sequence. 
This sequence also shows how 
one can compose sequences. 
Any fine of control within a 
sequence can be broken into 
another sequence, thereby 
creating a nested set of se¬ 
quences. The symbol we use 
to represent this sequence Is 
shown in Fig. 5. 




Single Entry/Exit Each of 
the above sequences has the 
property of only one entry 
point and only one exit point. 
In essence each sequence 
decomposes into a 1-in/1-out 
block box which allows three 
types of control structures to 
develop the logic: simple (or 
linear), decision (or analysis), 
and conditional (or induc¬ 
tion). 

Slight alterations of the 
control structure diagrams are 
permissible. However, the 
control structure sequence 
must do two things: 1) 
perform logically the control 
intended and, 2) have a single 
entry/exit. 

Program Flowcharts . All 
program flowcharts shall be 
realized by nested combina¬ 
tions of control structures. 
Any exceptions to this rule 
must be duly noted on the 
flowcharts. 

To reiterate, the flowcharts 
are functional in content to 
reflect what is being accom¬ 
plished at each step of the 
program. The flow diagrams 
are not intended to reflect 
the coding implementation 
but rather the logical func¬ 
tions which are to be per- 
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formed. 

Flowcharts should start at 
the top of a page and progress 
downward. This gives the 
appearance of the control 
structures entry and exit 
points in logical order. {Also 
it is suggested that the flow¬ 
charts be designed on stan¬ 
dard 8 y 2 x 11 paper. The 
reasoning for this is to limit 
conceptually the size of the 
functional block or block box 
designed by the control 
sequences. This is not a rule 
but rather a guideline, as 
some functional blocks do 
require more space.) 

Module. A module admits 
many descriptions. The term 
module will not be precisely 
defined but rather will be 
used to convey a concept. 
This will allow all design 
efforts to incorporate 
modularity. No matter what 
level of system description 
there is the concept of 
dividing up into parts. Each 
part is in essence a module. 


divided into input function, 
output analysis function, 
terminal scan function, etc. 
These parts of the system 
divide the system into 
modules. This unit then refers 
to a portion of the system. 
By defining how we divide 
the system, at the same time 
we specify the "connections" 
between the modules. Con¬ 
nectivity between the 
modules requires that the 
connection take place 
through the data base; i.e., 
the calling module does not 
imply information to the 
called module, the data is 
explicit. 

When a module is further 
divided into submodules the 
same process of dividing 
should be used. While the 
connection of these modules 
may not be exactly the same, 
the assumptions made about 
the connections should be the 
same. Therefore, the assump¬ 
tions which the modules 
make about one another have 
the same connection process. 

While not always practical. 


modules (and thus determin¬ 
ing the connectivity) should 
be the same at all levels. 
Regardless of the module, the 
connection between modules 
should contain as little 
information as possible and 
that information should be 
explicit. Since modules will 
not be defined at the same 
level of division within the 
system, the same procedure 
for dividing modules and 
definition for modules con¬ 
nectivity must always be 
used. 

Module Documentation . 
Each module should have 
documentation in the listing. 
All module documentation 
shall use a double remark 
{**) to distinguish it from 
other remarks generated 
during the coding. The fol¬ 
lowing information may be 
provided with each module. 

1. Name 

2. Functional Description 

3. Input Requirements 

4. Output Requirements 

5. Other Modules Called 
or Used 


7. Special Requirements 
to Use the Module 

Module Coding , Coding 
requirements must meet two 
criteria: efficiency and speed. 
While they are not necessarily 
compatible, they are essen¬ 
tial. An additional require¬ 
ment which cannot be 
measured objectively is 
comprehension. The module 
must be partitioned into 
meaningful and manageable 
units. These units are then in 
and of themselves modules. 

Each module must have 
structure and format in order 
to comprehend and read the 
coding. For best manage¬ 
ment, code as few line state¬ 
ments as possible. Novels are 
nice but they take longer to 
read and comprehend. 

Therefore to impose a 
discipline of writing programs 
a module should be limited to 
50 or fewer lines of code. 
Comments per lines of code 
should be numerous and 
descriptive, relating to the 
function being performed 
rather than the implementa- 


For example, a system is the procedure for dividing 6 . Registers Changed 


RS 232 INTERFACE 
CONNECTORS 

25 CONTACT 

1-9 10-49 50-99 

DB25S 3.90 3.25 3.00 

(socket) 

DB25P 2.65 2.20 2.00 

(pin) 

DB51226-1 1.60 1.30 1j00 

(damp) 

We stock a full line in this family of 
connectors. 

9, 15, 25, 37 and 50 contacts and 
coaxial units and a full stock of acces¬ 
sories, coax contacts hoods, shells, screw 
locks, sliding locks, etc. 

—We have “data phone" types— 

ORDERING INFORMATION: 
California residents add 6% sales tax 
All orders prepaid 
Foreign orders - U.S. funds only 

Orders under $15.00 add $1.00 shipping 
and handling 

Prepaid orders over $15.00. We will pay 
freight 


A-OK ELECTRONICS, INC. 
5855 W. Centinela Ave. 

LOS ANGELES, CA 90045 
(213) 670-2266 
TELEX 6533438 


THE COMPUTER MART 
OF NEW JERSEY 


501 Route #27 
iselin NJ 08830 
(201) 283*0600 

WANT SATISFACTION? We 
give expert advice and instruc¬ 
tion so you can choose the 
RIGHT hardware and KNOW 
how to use it. 

TRY US, YOU'LL LIKE US! 


WE STOCK 
*IMSAI 
*Lear Siegler 
# Tarbell 

* Seals 
*TDL 

*Cromemco 

* Processor Tech. 
Polymorphic 
*lcom and more 


WE SUPPLY 

* Service 

* Education 
*Advice 
^Software 

•Apple 
•Zapple 
•Disk Basic 
•Macro-Assembler 
and more 


Send SASE for your free 8080 
reference card. 


STORE HOURS: 

Mon. - Sat. 10 AM to 6 PM 
Evenings: 

Mon. & Thurs. Open until 9 PM 


tion on the computer. 


only 

1 * 9 * 5 . 





u. - 

Now you can cook-up 
hot programs on your 
“ 8080 ” 

A gourmet's delight of practical "how to" 
facts, including description of "8080" 
instruction set. How to manipulate 
"8080" stack. Flow charts. Source 
listings. Routines for multiple precision 
operation. Programming time delays for 
rest time applications. Random number 
generators. Completely assembled float¬ 
ing point math program. Input/output 
processing for basic I/O programming 
through interrupt processing. Code, 
numeric conversion routines. Real time 
programming. Search/sort routines. 
Plus many more finger-lickin’ goodies. 

Order your copy of Scelbi's "8080" 
Software Gourmet Guide & Cook Book 
todayl Only $9.95 ppd. Bon appetite! 




ICELBI COMMJIEU 7 

coNiumwo mi. y 

1322 Rear Boston Post Road 
Milford, CT 06460 • (203) 874-1573 
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6800 ? 


Now!! Have One Your Way 


The 6800 system owner can now have his best ideas in hardware on a 
buss compatable card designed to mate the SWTPC 6800 system. 



OToooooooooowoooooaoooooooooooisaoooooofloon 



• 2 sizes: CPU/memory size & I/O size 

• Will accept 14, 16, 24 and 40 pin connectors 

• Test and/or interface connections on top 

• 2 on-board regulator locations {1 on small board) 

• Short, low inductance power and ground 

• Use with wire wrap 

• Use with wiring pencil 

SEND MONEY ORDER, CHECK OR BANK AMERICARD # (We prefer Bank Americard) 

Personal Computing Company 

3321 Towerwood Drive, Suite 107 
Dallas, Texas 75234 


DEALERS INVITED 













































































































Computers in Golf 


... help for the handicapped 


CLOAD D 
OK 

LIST-120 

10 REM TO SCRATCH TYPE NINE COMMAS AND THEN CR 

20 REM TO INSERT HANDICAP, TYPE 200 THEN NINE COMMAS THEN CR 

30 REM THEN TYPE IN HANDICAP AND THEN CR 

40 REM TO CORRECT AN ERROR, TYPE 0 IN THE LAST ENTRY 

45 PRINT’TYPE DATE":INPUT A$ 

30 PRINT -.PRINT 

60 PRINT TAB(28)"HOUND EARS CLUB" 

70 PRINT 

80 PRINT" MEN'S HANDICAP - COURSE RATING 68.2 DATE: ";A$ 

90 PRINT:PRINT 

100 AE$-"ADDY, E.":AF$-"ALDEN. JAG$•"ALEXANDER, V." 

110 AH$""ANDERSON, A.":AI$-"ANDERSON, F.":AJ$*"ANDR£, H." 

120 BA$-"BEAN, B.":BB$*"BEAN, L.":BC$-"BEAN, P." 

500 DEFINT A 
510 DIM A(20) 

520 GOTO 800 

530 PRINT "MISTAKE IN ENTRIES" 

540 INPUT A(l),A(2).A<3),A(4),A(5),A(6),A(7).A(8),A(9),A(10) 

550 IF A(l)-0 THEN E-0: IF A<l)-0 THEN GOTO 720 
560 IF A(l)- 200 THEN GOTO 740 

570 INPUT A(U) ,A(12) .A(I3) ,A(14) ,A{15) »A(16>,A(17) ,A(18) ,A(I9) ,A<20) 
580 IF A(20)-0 THEN COTO 530 
590 F-0 

600 FOR 1-1 TO 19 

610 IF A(I) -A(I+1) THEN 640 

620 SWAP A(I),A(I+1) 

630 F-l 

640 NEXT I 

650 IF F-l THEN 590 

660 PRINT "TEN LOWEST SCORES ARE "j 

670 PRINT A(l) }A(2) ;A(3) ; A(4) jA(5) j A(6) ; A(7) ; A(8) ; A(9) ;A(10) 

680 T-A(l)+A(2)+A(3)+A(4)+A(5)+A(6)+A(7)+A(0)+A(9)+A(10) 

690 B-T/10:C-B-68.2:D-C*.96:E-INT(Df.5) 

700 IF E 40 THEN E-40 
710 PRINT "HANDICAP IS ";E 
720 PRINT 
730 RETURN 

740 INPUT E.-GOTO 710 
800 PRINT AE$:GOSUB 540:REM ADDY 
810 AE-E: PRINT AFS: COSUB 540: REM AUDEN 
820 AF-E:PRINT AC$:GOSUB 540:REM ALEXANDER 
830 AG-E:PRINT AH$:COSUB 540;REM ANDERSON,A 

1850 PRINT"ADJUST PAPER AND CONTINUE" 

1860 STOP 

2000 PRINT:PRINT:PRINT 

2010 PRINT TAB(28)"HOUND EARS CLUB" 

2020 PRINT 

2030 PRINT" MEN'S HANDICAPS - COURSE RATING 68.2 DATE: ";A$ 

2040 PRINT:PRINT:PRINT 

2100 PRINT AE$:TAB(15)AE;TAB(25)GA$;TAB(40)CA;TAB(50)PA$:TAB(6S)PA 
2110 PRINT AF$;TAB(15)AF;TAB(25)GB$;TAS(40)GB;TAB(50)PB$;TAB(65)PB 
2120 PRINT AC$;TAB(15)AC;TAB(25)GC$;TAB<40)CC 
2130 PRINT AH$;TAB(15)AH 

2140 PRINT AI$;TAB(15)AI;TAB(50)RA$;TAB(65)RA 

2150 PRINT AJ$;TAB(15)AJ;TAB(25)HA$;TAB(40)HA;TAB(50)RB$;TAB(65)RB 
2160 PRINT TAB(25)HC$;TAB(40)HC;TAB(50)RCS;TAB(65)RC 
2170 PRINT TAB(25)HD$;TAB(40)HD;TAB(50)RD$;TAB(65)RD 


Fig. 1. The golf handicapping program (in Aftair Extended 
BASIC). Rather than reproducing the entire data base of 
member's names, only a few are included as examples. 


When / was involved with the Micro-8 Newsletter, as a 
co-editor, one of the most interesting fetters I ever published 
was written by George Haller describing his golf handicapping 
program. (At the time I didn't consider the program very 
practical ... but definitely interesting!) George's original 
program was written for his Sceibi 8008system; however, this 
article, reflects bis update of that program for his Aftair 
8800/Disc system using MiTS Extended BASIC. I have also 
been updated in that I can see, and appreciate, the small 
business money-making potential here. We can also thank 
George for coming up with a suggestion for a "BASIC 
Questions & Answers" section in Kilobaud which fed to the 
BASIC Forum by Dick Whipple and John Arnold. — John. 


George L. Haller 
1500 Galleon Dr. 
Naples FL 33940 


H andicapping for golf 
associations is not only 
a most interesting application 
for a small computer but can 
also be a possible source of 
revenue. 

Calculating The Handicap 
Club handicaps are usually 
calculated on a monthly basis 
and are done in a variety of 
ways. If the group has few 
members the golf professional 
usually does the calculations. 
As the club grows, a handicap 
committee is formed which 
meets once a month and does 


the work, probably using a 
hand calculator and allocating 
parts of the job to various 
members of the committee. If 
the size of the group increases 
to much over 100 members, 
the job of handicapping 
becomes too onerous and 
relief from outside services is 
sought. If the association is 
quite large, say over 400 
members, then a full com¬ 
puter service with a storage 
terminal at the club is quite 
often used. The business 
applications for the small 
computer operator is usually 
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HOUND EARS 

CLUB 



KEN*5 HANDICAPS 

- COURSE RAT1SXJ 68.2 

DATE: l AUGUST 1976 

ADDY. E. 

18 

GARLAND, C. 

11 

PEARSON, E- 

17 

ALDEN. J, 

11 

GOODMAN. E, 

6 

PHIIilFS. C. 

17 

ALEXANDER, V. 

ID 

GRYDER. D. 

16 



ANDERSON, A. 

12 





ANDERSON, F. 

15 



RANKIN. J. 

32 

ANDRE, M. 

8 

HALLER, G, 

23 

RIDENHOUR, J. 

14 



HARTLINE, H. 

11 

ROBBINS, H. 

n 



HENSLEY. 5. 

16 

ROBBINS, S- 

10 

BEAK. P, 

14 

HERMANN, R, 

24 



am,, w. 

18 

HUNTLEY, H. 

11 



BOLT,‘ESS, R. 

17 



SCATTERG00D. A. 

26 

HEADY, C. 

11 



SCHLESINGER. R. 

9 

BRADY, E, 

17 

JOHNSON, J, 

7 

SCHL0SS, J. 

11 

BRANSTROM, W, 

12 

JOHNSON, R. 

11 

scom, w. 

18 

BREWER , C, 

19 



SHAPARD, R. 

7 

BUTLER, W, 

9 



SHEALY, J . 

16 



KEISTER, E. 

7 

SHQWELL, L, 

31 



KEYES, C. 

15 

SINGER, L, 

9 

CAUSEY, G. 

5 

KILL!BREW, C. 

34 

SMITH, R. 

12 

CHEEK. L. 

14 

KOSTEN. L. 

6 

STEPHENS„ ?. 

B 

CHURCH, J. 

C 

KRAMER, E. 

14 

STOKES. C. 

18 

CLARK, W, 

n 



SUTHERLAND, J. 

12 

CLOGSTON, R. 

6 





COFFEY, F. 

15 

LAFFERTY, K. 

26 



COLEMAN, F, 

15 

LEATH. V. 

8 

TATE, S. 

16 

COLVERT, K. 

16 

LEFCOURT. S. 

20 

THOMAS, J , 

13 

CONE, », 

28 

LJSK, B. 

6 

THOMPSON, C, 

17 

COX, A. 

17 

LUCE, C. 

13 

TINGLE, C, 

27 

CHOTHERS, H. 

14 



TUCKER, L. 

9 

CUSHING, A. 

2fl 







MG KAUGHN. R. 

13 





MC LAURY, E. 

u 

VELDE, L, 

9 

DAVIS, F, 

14 

MABRY, C. 

24 



BILLING, J , 

7 

MANN. J. 

10 



DURANT, R. 

17 

MARION, J, 

10 

walsworth. c. 

is 



MICHNQFF. D. 

9 

WALT), 0, 

3 



MITCHELL, N. 

18 

WILLIAMS, J, 

7 

EDWARDS, M, 

11 

MORRIS, L. 

18 

WILLIAMS. If. 

23 

ELFHON, s. 

33 

MORRISON. S. 

10 

WISE. F. 

14 

EWING, M. 

19 

MORRISON, R. 

6 

WOLFSON. R, 

14 



MOTES, L 

9 

WOOTEN, R. 

12 

FALLOWS, R. 

4 






25 

NEWMAN. H. 

19 



nCHTENGER, C. 

22 

NEWTON, E. 

7 



FISCHLEY, W, 

3® 





FURR. F. 

13 





FURRY, G. 

IB 





OK 







Fig. 2. Print-out of club member's handicaps. 


found in the medium sized 
dub and fees from $Z0G to 
S3.00 per member per season 
can be charged. The club 
professional, or a member of 
the handicap committee, 
would he the first person to 
talk to about the service. 

Depending on the size of 
the group, the handicapping 
is done in different ways, but 
always using the same basic 
formula. This formula takes 
the average of the ten best 
scores from the most recent 
twenty games played. From 
this average the United States 
Golf Association course 
rating is subtracted, and the 
result is multiplied by 0.96 
and rounded. This result is 
then the individual player's 
handicap. For example, if the 
average of the ten best scores 
out of the most recent 
twenty games of regulation 
18 holes is 93.2 strokes, and 
the course rating is 70.1, then 
the handicap is integer 22 
(93,2 - 70,1) (0.96 = 22). The 
handicaps are used to match 
players of varying degrees of 
skill. All holes on a golf 
course are rated according to 
their difficulty from 1 to 18, 
with 1 being the most dif 
ficult hole, tn a handicap 
match players are allowed to 
deduct strokes from their 
hole scores according to their 
handicap. Thus, a player with 
a 22 handicap would be 
allowed to deduct (from his 
or her hole scores) one stroke 
on each hole and an addi- 
tional stroke for each of the 
holes handicapped at 1 
through 4. A player with a 9 
handicap would only be 
allowed to deduct one stroke 
each on handicap holes 1 
through 9. 

Handicaps can also be 
determined by taking the 
difference between two 
players' handicaps and using 
that value in the following 
manner: The player with a 22 
handicap playing against the 
player with a 9 handicap 
would be allowed a stroke on 
each of the handicap holes 1 
through 13 (the difference 
between 22 and 9), and the 
player with the 9 handicap 
would play "scratch' 1 (no 


strokes deducted on any 
holes). In the case of a four* 
some, the player with the 
lowest handicap would play 
from "scratch" and the other 
three players would be 
allowed strokes based on 
their handicaps. The profes¬ 
sional players that we see 
playing on TV are all con¬ 
sidered to be zero handicap 
or "scratch" players. Handi¬ 
capping doesn't enter into TV 
or professional tournaments, 
but most amateur play is 
done on a handicap basis and 
the handicap is a very impor¬ 
tant part of each player's 
record. 

The Program 

The program (Fig. 1) using 
ALTAIR Extended BASIC, is 
one used at a club that has a 
total of about 175 men and 
women players. Running 
separate programs for both 
men and women takes about 
four hours per month. Rather 
than listing the entire pro¬ 
gram, we've given excerpts 
which show the pertinent 
parts of the program without 
long lists of repetitious 
entries. Basically, the pro¬ 
gram prints a member's name 
and then accepts the 20 most 
recent scores. The scores are 
then sorted and the ten 
lowest scores are printed. 
The handicap is then calcu¬ 
lated and printed, and the 
next member's name is 
printed for the inputting of 
his scores. This material is 
turned over to the club pro¬ 
fessional for member refer¬ 
ence. Next, part of the pro¬ 
gram prints a summary of the 
names and scores which is 
then posted on the dub 
bulletin board (Fig. 2). 

Now ... let's take a look 
at the details of the program. 
Lines 10 through 40 refresh 
the operator's memory as to 
how to handle the inputs. 
Lines 20 and 30 explain how 
to handle a direct handicap 
input if no new scores have 
been posted and line 45 
inputs the date to be used in 
the headings. Lines 100 to 
499 are used to list the 
members' names with their 
two letter string variable. 


Lines 500 and 510 set the 
dimensional array. We then 
go to line 800 which prints 
the first member's name and 
goes to a subroutine starting 
on line 540. Line 540 calls 
for an input of the first ten 
scores. Line 550 scratches 
that entry if the first entry is 
a zero. If the first entry is a 
200, then the subroutine is 
terminated and the numeric 
handicap (variable "E" in the 
program) can be inputted 
directly. 


Fig. 3 shows a heading and 
an example of a normal input 
of 20 scores under the name 
"Addy, E." An example of a 
directly inserted handicap is 
shown under the name 
"Aklen, J." Line 570 inputs 
the second 10 of the 20 
scores. These scores were 
divided into two blocks of 
ten for terminal width rea¬ 
sons, If a mistake has been 
made in the entry of any 
score, we enter zero for the 
last score and the computer 


DK 

RUN TYPE HATE 
J IS AUG 1976 


HOUND EARS CLUB 

WEN'S HANDICAP - COURSE RATING 63.2 DATE; 15 AUG 1976 


ADDY. E. 

? 37,86,88,87,85.86,94,58.99.91 
7 85,89,89.90,90,89,36,92,88,SB 

TEN LOWEST SCORES ARE 65 35 86 86 86 67 87 83 83 86 

HAND!CAP IS 13 


HANDICAP IS II 

ALEXANDER, V. 

7 

OK 

GOTQ20O£ 


Fig. 3. Sample print-out during updating or entering of new 
scores for computing of handicap. 
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UP YOUR. 

Memory 

^★★★★★★★* ★★★***■*'****■** 
Fast, Low Fbwer 2102 

$1.60 Beat This!!! 

aaactaaaaaaaaaaaaactaaaaaadittccaaaaGtaaaaaaaau 

4K RAM Board Kit $7995 

- LOW POWER 2102 

- DENSE 4V'X 6" PACKAGE 
-STANDARD AA PIN 

GOLD PLATED CONNECTOR 

laaaaaasaaaaaa saaaaaaaa^Ddiaaaaetaotaaattaaaa 

6800 OEM Prototype Board 

INCLUDES SOCKETS $42.50 

taaaaaaaaaaaamaaaaaattaaaaaaaaaaaa^aaa aaaai 

For orders under $25.00, 
add $2.00 shipping and handling 


WASATCH SEMICONDUCTOR PRODUCTS 

25 South 300 East, Suite 226 
Salt Lake City, Utah 84111 

OEM INQUIRIES INVITED 


prints "MISTAKE IN 
ENTRIES/' We then start 
over with that player's 
entries* Lines 590 through 
650 are a sorting routine. If 
your BASIC does not have a 
"SWAP" command, another 
sorting method will have to 
be used. Lines 660670 print 
the ten lowest scores. Lines 
680 through 700 calculates 
the handicap and assigns its 
value to the variable E, The 
handicap is then printed, with 
the statement "HANDICAP 
IS/' under the ten lowest 
scores* We then return to the 
next player name input, line 
810* Note that the first state¬ 
ment in line 810 stores the 
previously calculated handi¬ 
cap value E in the double 
letter variable AE, which is 
associated with the player's 
name string variable $AE. 

This operation continues 
until we have completed the 
inputting of scores for all 
members. We then arrive at 
lines 1850-1860 which allows 
us to adjust the paper, so that 
we can start on a complete 


sheet, before giving the 
"CONT" command* The 
computer then prints out a 
summary sheet as shown in 
Fig. 2. More copies of this 
sheet can be made by adjust¬ 
ing the paper and giving the 
command "GOTO 2000/' 

Conclusion 

This program, like most, 
could probably be improved. 
A suggested next step would 
be to save all scores as data 
and input only the new 
scores, which would delete 
the older scores and stilt leave 
a total of twenty* Another 
would be to print the old 
handicap as well as the new 
on the summary sheet. This 
would be a much more 
complicated program, but 
would save some time in 
inputting scores where fewer 
than twenty scores were 
posted for the past interval. 
There are probably other 
ways to change the program, 
but it is running successfully 
as described here. That is, of 
course, the main objective, ■ 


6502 OWNERS 

assembler/text-editor program 

In source and object form, 

ANSI basic program 
star trek gome program 

All above programs run in 4K 
memory. Available on either 
cassette or paper tape. 


PROGRAMS $19.95 EACH PPD. 
(Texas Residents add 5% sales tax) 


Ha rd copy available with 
purchase for an additional $12.95 
ppd, Membership in User Group 
with purchase. Complete listing of 
programs available on request, 

MICRO SOFTWARE SPECIALISTS, INC 

2024 Washington Street 
Commerce TX 75428 
(214) 886-6300 


VECTORBORD® TENTH/TENTH HOLES MOUNT: 

DIPS, SIPS, KLIPS, CHIPS 

PINS, POSTS, POTS, PADS Save Work — Time — Money 

RCs, f Cs, PCs , SCs 



Pattern M P M 


{Component Side vvitn Added Sockets) 

Has 100 contacts on O * V* centers, is 10” wide by 5.313” 
high. Has heavy Tinned back-to-back buses M overall 0 , 1" 
spaced 0.042” hole pattern. Socketed models available. 


8800V MICROPROCESSOR PLUGBORD 


Pattern “H- 


f] 


T2B V 


Fits 


,0G2" n 


| Holes J 


*042" 

Did* 


• tti 


-. 062 ' 

Dia. 


WIDE SELECTION OF SIZES AND MATERIALS 


MIC8O-VECTORBORD"P" - Q.Q42" 
holes match DIP leads* Epoxy glass, or 
glass composite, paper, copper dad. Also 
1/64"to 1 /16" thick and 1 6" max. width. 


TERMINALS— Complete selection of 
wire wrappable and solderable push-in 
terminals for 0.042'and 0,062" dia. holes 
— plus wiring tools avEiilable, 


VECTORBORD **W* — For larger termi¬ 
nals, leads. Available In epoxy glass sheets 
4.8" to 8.5" wide and 8,5" to 17" long. 
1/32" and 1/1G" thick. 


PLUGBORDS — For solder or wrap wire 
construction 2,73" to 10" wide and 4,5" 
to 9,6" long. With holes .V'x .1", ,1"x 
*2", ,2"x .2”, or loaded with 1C sockets. 



$rnd for complete literature 

ELECTRONIC COMPANY, INC. 

12460 Gladstone Ave*, Sylmar CA 91342 
(2131 365-9661 - TWX (9101 496-1539 
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After you get through splitting a gut on this one, be sure and 
show it to your wife. She'll enjoy it for sure. — John. 


Computer 

Widow 



Barbara Henderson 
3998 Berry wood Drive 
Santa Maria CA 93454 


D o you think you have 
problems? I'm married 
to one of the worst computer 
nuts the world has ever 
known. And when my hus¬ 
band becomes interested in a 
hobby, we all better look 
out! His dedication in 
building his microcomputer 
system this past year has been 
nothing short of a trial for 
me. 

Now that I think about it, 
I can see that he has been 
preparing me for this heavy 
involvement for quite a few 
years. First came the radio- 
controlled model airplanes, 
with everything from a scale 
model J*3 to a homebuilt with 
a nine-foot wing span. 
Presently there are seven air¬ 
plane carcasses hanging in the 
garage, all in various states of 
disrepair. After the model air¬ 
planes, a private pilot's 
license was next on his list 
However, after a few short 
(and harrowing) flights and a 
couple of white-knuckle 
landings, he conceded that 
this hobby was not very prac¬ 
tical. Then, there's the water- 
ski boat out beside the house; 
it's been in the water once in 


the past four years. And, the 
complete welding setup - 
just in case anything ever 
needs to be welded. Oh, and 
we mustn't forget the motor¬ 
cycle which he rides maybe 
twice a year. 

But, his interest in these 
past hobbies appears to be 
nothing compared to his 
obsession with computers. I 
think we have enough com¬ 
puter equipment around our 
house to be able to replace 
IBM at a moment's notice. 
On the larger side, there are 
the two eight-foot tall strip 
chart recorders which were 
too good a deal to pass up. 
Then, there are the five paper 
tape punches (does one com¬ 
puter system really need that 
many?). As far as keyboards 
go, we are now the proud 
owners of four, with the ex¬ 
planation that each one was 
just a little better than the 
others and he was really 
trying to get one that / would 
enjoy using. That sounds like 
quite a bit of equipment for 
one Altair 8800, doesn't it? 
But the best is yet to come. 
We added on a larger family 
room, to have additional 
space to live in (I thought), 
but our old family room has 
now been taken over by two 
gigantic disc drives. Since 
they each cost about $8000 
new, he got such a good deal, 


I'm sure it would have been 
criminal to pass them up! 
When friends come to visit, 
they wonder if the discs are 
my new model washer and 
dryer, or his-and*her steam 
baths, or just what. The disc 
drives can't be out in the 
garage workshop with all the 
other equipment, though. 
Why? Because they can't be 
around all those soap and 
bleach fumes from the 
clothes washer! I sometimes 
wish that I were as pampered 
and well cared for as his 
equipment. I'll bet there's a 
lot more 24 karat gold in that 
Altair than there is in my 
jewelry box! 

I guess it should be under¬ 
standable that all this equip¬ 
ment would require his 
seemingly constant attention, 
but there are more things 
being neglected around our 
house than just me. Our 
children hardly recognize 
their own father unless he's 
perched on his work stool in 
the garage. Then there is the 
backyard fence which was 
blown over last spring in a 
heavy wind. The new family 
room has a lot of unfinished 
electrical work and wood 
paneling that hasn't been 
touched for eight months. 
There are leaky faucets in the 
kitchen and bathroom which 
are rusting from neglect. And 


get this: There is a rather 
conspicuous 300 gallon hot 
water tank beside the house, 
waiting to be used some day 
in a solar heating system. 
Maybe. But in the meantime 
I'm about to run out of 
Excedrin tablets! 

I've been thinking about 
forming a Central California 
Computer Widows' Club for 
all of us neglected wives. I'm 
sure there are many out there 
who feel as I do (as a matter 
of fact, it should probably be 
a national organization). We 
could get together and learn 
how to program and repair 
computers so we could spend 
more time with our husbands, 
or maybe learn how to 
sabotage the monsters so we 
could get even! Or maybe we 
could just get together and 
cry a lot. 

After due consideration, 
though, I don't think I would 
trade my husband for any¬ 
body, even though he appears 
to have terminal computer 
disease. At least he doesn't 
spend every night in front of 
the TV, sacked out on the 
couch, or out with the boys. 
And, whenever I need him, all 
I have to do is open the 
garage door ... and there he 
is. So I can talk to you any 
time I want, can't I, Honey? 
Honey? Are you listening? 
Honey? ■ 
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This article was written some 
months hack , and since then 
the Digital Croup has come 
up with a nice collection of 
cabinets to house the various 
subassemblies which make up 
their system. With a couple of 
a ddi tions, the comn i en ts at i d 
observations f made regarding 
their system still hold true 
(90% favorable, I might addl 
The first additional comment 
concerns the Digital Group 
monitor program and the fact 
it resides in page zero. This 
seems to cause problems 
when it comes to loading 
other software in almost 
every instance. One owner , / 
know even went so far as to 
put a switch in which a!lowed 
him to select between the 
monitor's PROM or RAM 
memory in page zero. Natu¬ 
rally, he still isn't ah/e to use 
the PROM for loading pro¬ 
grams into page zero . . . the 
answer seems to fie in relo¬ 
cating the monitor elsewhere 
in memory. The second addi¬ 
tional comment concerns the 
fact the Digital Group didn't 
go with the A itair bus . 
Granted their bus layout may 
even be better than the 
Altair, there are still a lot of 
occasions when a Digital 
Group owner would like to 
have one of those peripherals, 
or options , which plugs into 
the A Itair. On the other hand , 
there are probably a lot of 
A Itair system owners that 
would like to be able to use 
the Suding Phi-deck con¬ 
troller or video driver or 
wha tever. I f someone has 
de ve/op ed a Dig ita I- G roup - 
to-Altair interface (or is 
thinking about it}, Kilobaud 
Magazine would be tickled 
pink to pay you welt for the 
plans fee., a construction 
article), — John , 



The Digital Group System (posing for a photo). Slatting a 11 op-center and going clockwise: the 
Sanyo Monitor; substitute El Cheapo (but good) Roberts cassette recorder (normally a 
Super scope CD 04); some of the gobs of software available on cassettes; the keyboard; the 
motherboard f with the four boards of a basic system plugged in (SK of RAM, CPU board w/2K 
of RAM , video and cassette interface hoard\ and the I/O board with four in pul and four output 
ports) with room for memory and I/O expansion; and last, a more than adequate power supply. 


What’s that 
Digital Group 
Really Doing? 


John Craig 
Editor 
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I f you can design and build 
a microcomputer system 
that will play the Star- 
Spangled Banner through an 
AM radio and at the same 
time generate an American 
flag on a TV screen, it doesn't 
really have to do anything 
else! The average layman will 
be so fascinated by i his 
demonstration that the last 
thing in the world he'll ever 
ask is, 11 But what are you 
going to use it for?” (You've 
heard that one before, right?) 

Dr, Robert Sliding 
W0LMD is the man behind 
the design of the Digital 
Group System, and you can 
rest assured that the system is 
capable of doing much more 
than playing the Star- 
Spangled Banner* One of the 
main objectives behind the 
design of the system was to 
make it a truly ”turn-key" 
system (Lc., build it, connect 
the various components, 
apply power, and begin oper¬ 
ating}, I'm here to tell you 
he/they did it! 

There are several things 
about the system which are 
impressive just from first 
glances. Quality prevails in 
almost every instance (and, 
I'll be sure and due you in on 
the one or two places I feel it 
doesn't .., keep count, t think 
it's only ONE). Upon walking 
up to one of these systems, 
your eyes first fall upon the 9 
inch Sanyo monitor (not a 
regular TV) and the sharp, 
dear characters being dis¬ 
played, The character set 
includes both upper and 
lower case, as well as the 
Greek alphabet (just what 
you always wanted, right?). 
The quality of the PC boards 
is equal to, if not better than, 
boards I've seen put out by 
some of the biggies, The 
cassette recorder sold with 
the system is a Superscope 
C-104 with variable speed and 
other neat features. It's a 
rather expensive unit 
($119,50), hut then il‘s really 
the heart of the system and 
they figured it shouldn't be 
compromised, 1 might add, 
however, that the system I 


worked with didn't have this 
recorder with it, so I pro¬ 
ceeded to connect my $24.95 
Roberts recorder (pictured in 
the upper right-hand corner 
o f t he photo) a nd d i d n ’ t ha ve 
any problems with reading 
prerecorded programs. 

The keyboard was the one 
item which t dldn'l get too 
excited about. In ihe docu¬ 
mentation supplied with the 
system they make quite a 
point of the fact that if 
you're dissatisfied with any 
item they welcome its return. 
Therefore, if a body fell as l 
did about this keyboard, it 
could certainly be returned 
for a refund or an exchange, 
and I understand they wilt he 
offering a different model (or 
models) in the future, 

CPU-Independent Architec¬ 
ture and Upgradability 

A very unique, and cer¬ 
tainly worthwhile feature of 
the system is the fact that the 
architecture isn't dedicated to 
any one particular micro¬ 
processor. The 8080 CPU 
board is the most popular, 
but DG also offers a CPU 


board which has your choice 
of a Motorola 6800 or a MGS 
Technology 6502 (with only 
two or three jumpers 
necessary to go from one to 
the other}. There's going to 
be a lot of software 
developed within the 
hobbyist community for all 
three of these processors, and 
t h c r e aren't l oo many 
systems around offering this 
capability. 

And, talk about upgrada¬ 
bility H How's about up¬ 
grading to the ZILOG Z-80?? 
The Z-80 has got to he one of 
the hottest items to come out 
of the Silicon Valley in quite 
some time ,, , and DG has 
put together a CPU board 
using the little beast. Here are 
just a few of its worthy 
fea Hires: 1) Refresh for 
dynamic memory is generated 
internally within the chip, 
and the refresh address 
register can be accessed for 
random number generation 1 
2) Two sets of six general- 
purpose registers, which can 
be combined in pairs to form 
16-hit registers, 3) Instruc¬ 
tions for moving any size 


block of memory and also for 
searching a block of memory 
for a particular value. 4) Bit 
manipulation instructions. 5) 
And more .,, 

Construction 

The unit I worked with 
was already built and run¬ 
ning, but a friend of mine, 
Robert WhiLe, recently con¬ 
structed a DG system and had 
some worthwhile comments. 
Perhaps the most significant 
was the fact he felt the con¬ 
struction documentation was 
adequate for the job. He 
brought up the system by 
plugging each board into 
someone else's unit (which is 
one of the advantages of 
finding another unit in your 
area , , , during the firing up 
of any system). He also men¬ 
tioned that a scope was 
necessary for checking the 
timing and performing the 
cassette board alignment On 
a scale of \ to 10, he gave the 
unit a resounding 10, 

The Digital Group System 
doesn't have a from panel. If 
you've ever had occasion to 
t r o u b I eshoo t a com puter 
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Features (displayed on the screen after reading in the TBX-TVCOS 
cassette): 

1. READ BASIC Program (from cassette) 

2. WRITE BASIC Program (to cassette) 

3. Display Commands (displays an unannotated list of TBX 
commands on TV screen) 

4. Display Error Codes (annotated list of TBX error codes listed on 
TV) 

5. Continue Programming (useful for exiting and re-entering BASIC 
program during debugging) 

6. TINY BASIC (causes entry into TBX for writing BASIC 
programs) 

TBX Commands: 

LST — List Program 

RUN - Execute (run) resident program 

NEW - Start new program (& "scratch" old) 

SZE — Display resident program size 

PR - PRINT output data 

IN — Enter (INPUT) a value from keyboard 

LET - Assign a value to a variable 

IF - Conditional test statement 

FOR - Beginning of a loop 

NXT — End of loop 

GOTO - Alter program execution sequence (Jump) 

GOSUB - Jump to subroutine 
RET - Return from subroutine 

DTA - Assign value(s) to simple or single dimensioned array variable 
(equivalent to LET) 

DIM - Assign array dimension(s) 

END - End of program 

Table /. Tiny BASIC Extended TV-Casette Operating System, 
Features and Commands . 


without a front panel, per¬ 
haps you can appreciate the 
value of one. (Very handy for 
single-stepping through a pro¬ 
gram or entering short 
troubleshooting routines ... 
so you know exactly what 
the machine is doing, rather 
than trying to also figure out 
what’s going on with the 
Monitor program.) The 
Digital Group folks appar¬ 
ently didn’t go the front 
panel route because of the 
reliability of their unit. But 
for those desiring one, they 
have very thoughtfully pro¬ 
vided construction plans for 
building one. 

The Software l 

Digital Group Software 
Systems, Inc. (DGSS) is a 
company formed by DG for 
software distribution. The 
operation is run by Charles 
and Dianne Howerton in 
Arvada, Colorado. They try 
to ship all orders within a 24 
to 48 hour time frame ... 
and if they can’t, notify the 
customer. All shipments are 
guaranteed, and they’ve 
replaced several cassettes that 


have developed “glitches’ 1 
after being shipped. They 
pointed out that it is very 
unwise to place cassettes on 
top of, or beside, TV mon¬ 
itors ... especially those with 
metal cabinets. 

When power is initially 
applied to a Digital Group 
System, the message “READ 
8 0 8 0 I NITIALIZE 
CASSETTE” appears on the 
monitor screen. One simply 
starts the cassette recorder at 
the beginning of the program 
to be loaded, and when a 
steady tone begins, the reset 
button is pushed and re¬ 
leased. At the end of the tone 
leader, the program is read 
into main memory. The TV 
displays the least significant 
digit of the octal page cur¬ 
rently being loaded, byte by 
byte (so you can “see” the 
program as it’s coming in). 
Memory is also checked byte 
by byte and missing or defec¬ 
tive memory addresses are 
indicated by a period (“.”) 
rather than the octal digit of 
the page. This cassette loader 
program in ROM is further 


evidence of the “turn-key” 
characteristic of the system. 

Following is a list and 
brief description of some of 
the neat software available 
from Digital Group Software 
Systems: 

TINY BASIC EXTENDED 
TV-CASSETTE OPERA TING 
SYSTEM - Developed by 
Dick Whipple and john 
Arnold of Tyler, Texas. Tiny 
BASIC Extended (TBX) was 
their baby, and Dr. Suding 
interfaced it with TV and 
cassette drivers to come up 
with the Operating System 
(TBX-TVCOS). A very neat 
package, and easy to use. 
Table 1 lists the features and 
commands available with 
TBX-TVCOS. 

8080 OPERA TING 
SYSTEM (standard with the 
system) — Provides the user 
with cassette read and write 
routines, memory dump, and 
machine language program¬ 
ming capability from the key¬ 
board. Also has a “calling” 
feature so that the user can 
call up a particular program 
or routine in main memory 
and run it. This cassette also 
includes five demonstration 
and diagnostic programs: 

1. Computerized 
Amateur Radio ... 
with a “CW Keyboard” 
routine (speed selecta¬ 
ble) and a “RTTY Re¬ 
ceive” routine for con- 
verting frequency 
shifted 60 wpm Baudot 
to ASCII and displaying 
the characters. (Very 
simple to implement.) 

2. Synthesized Music 
... described earlier,.. 
that’s the program that 
plays the Star-Spangled 
Banner while drawing 
an American flag on the 
monitor. (Interesting 
insofar as a regular AM 
radio is used to pick up 
the music ... resulting 
from frequency modu¬ 
lating the data paths 
with different timing 
loops.) 


3. 75 Hz to 10 kHz 
Frequency Counter ... 
developed by imple¬ 
menting a very small 
amount of external cir¬ 
cuitry (an FET, a tran¬ 
sistor, etc.) and samp¬ 
ling an incoming audio 
frequency using the 
CPU’s crystal-con¬ 
trolled clock. 

4. CPU Interrupt 
Handler Diagnostic 

5. Memory Diag¬ 
nostic ... right down 
to the bad chip. 


THE GAMES ... AND 
MORE GAMES - Computers 
are for kids (young and old), 
and DGSS has certainly put 
together an impressive collec¬ 
tion of games written in 
Tiny BASIC. They have (at 
the time this was written, 
anyway) four cassettes of 
Tiny BASIC games ... each 
cassette with five or more 
games. The number of pro¬ 
grams prevents them from all 
being listed here, but some of 
the more popular ones are: 
CHOMP, CHECKERS, TIC- 
TAC-TOE, BIORHYTHM, 
TRAP, BLACK-JACK, 23 
MATCHES, plus some good 
educational and simulation 
game programs. Also, avail¬ 
able on a separate cassette are 
the game of KINGDOM and 
two versions of LIFE. 

EDUCATOR-8080 - 
This is a very interesting pro¬ 
gram which demonstrates the 
effect executing certain in¬ 
structions has on the status, 
Accumulator, and B and C 
registers of an 8080. All of 
them are displayed on the 
screen; you enter an instruc¬ 
tion and then see the change. 
Quite a program for a teach¬ 
ing environment. (The only 
limitation was the fact that 
memory reference instruc¬ 
tions couldn’t be executed.) 

The cassettes are reason¬ 
ably priced at $5 to $10 ... 
are recorded on high-quality 
tape ... and are checked 
before shipment. Listings are 
not provided in an effort to 
keep the cost down ., . but 
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perhaps they can be pur¬ 
chased for additional bucks. 
All in all, it's a very impres¬ 
sive collection of sol i ware, 
and certainly one of the high¬ 
lights of the system. 

Summary 

I like it! As I’ve pointed 
out, the various assemblies 
and peripherals which make 
up the system were easy to 
interconnect, and the avail¬ 
able software gives you some¬ 
thing to work and play with 
. . . now. 

The Digital Group does 
not go along with the Kansas 
City Standard for cassette 
interfacing because it's loo 
slow, compared to theirs. ! 
don't consider this to be a 
major drawback, since it 
appears that an adequate 
amount of software will be 
available through DGSS. If 
you’re going to be buying a 
system with the idea of doing 
a lot of software exchanging 
with others (who use the KC 
Standard), then you should 
keep this in mind. 


By the time this article 
goes to press, the Digital 
Group should have among ils 
offerings a selection of 
cabinets and keyboards, and 
most important, a very 
sophisticated dual Phi-deck 
cassette controller and drive 
system. 

The system is not for 
everyone, because it isn't the 
least expensive on the 
market. I do believe, how¬ 
ever, that you can be assured 
of getting your money's 
worth. (They don’t have any 
qualms about selling portions 
of the system ... as a matter 
of fact, they've published 
plans for converting an 
ordinary TV into a monitor 
. . . and, as I pointed out, you 
can probably get by with a 
less expensive cassette re¬ 
corder.) If you would like to 
contact them for further 
information, the address is: 
The Digital Group, P.O. Box 
6528, Denver CO 80206. 
They're very helpful folks, 
and Pm sure they would like 
to hear from you, * 



The Tarbell Cassette Interface 

• Plugs directly into vour IMSAI or ALT AIR 

• Fastest transfer rate: 187 (standard) to 540 
hytes/second 

• Extremely Reliable — Phase encoded (self- 
docking) 

• 4 Extra Status Lines, 4 Extra Control Lines 

• 25-page manual included 

• Device Code Selectable by DIP-swilch 

• Capable of Generating Kansas City tapes also 

• No modification required on audio cassette 
recorder 

• Complete kit SI20, Assembled SI75, Manual 
$4 

TARBELL ELECTRONICS 

144 Miraieste Drive #106, Miraleste CA 90732 
(213) 538-4251 

California residents please add 6% sales tax 




inscription 



Quite a few subscribers to Kilobaud have asked 
about a life subscription. For a limited time this will 
be available . . . as a convenience to readers who don't 
want to be bothered with yearly billing for subscrip¬ 
tions. 

Inflation seems to be a way of life and is going to 
continue. The word is that paper costs are going to 
double in the next year, as will postal costs in the 
next year or so. This means that SI 5 subscriptions for 
magazines will go to $20, then $25 . . . and so forth. 
With a 5 $ (1940) ice cream cone now running over 
50d and 20d magazines running about 32 per copy, in 
a few years well be used to paying $5 per copy , . , 
then $10. 

The first copies of 73 were 31$ and a lifetime 
subscription was $37, Now copies are $2 and the 
lifetime is $1 50 . . . and going up to S20C soon. 

The plans are to sell no more than 1000 life 
subscriptions to Kilobaud. There are some good 
reasons for this, obviously . . . like those mentioned 
increases in costs. Don't be disappointed by waiting 
too long. 

Time payments? Sure ... send in $50 down and 
we'll bill you $25 per month for four months for the 
balance . . , well take cash, check, money order, 
BankAmericard, Master Charge, American Express. 
We're very easy to get along with. 

What about your present three year for $25 
subscription? If you act now (to coin a phrase) you 
can deduct that from the bill. Act now. 


$-enclosed □ cash □ check. □ money order 

□ Paid in full □ Time payment - $50 down, $25 per 
month for four months 

Charge □ BankAmericard □ Master Charge 


□ American Express 

Card # ____ 

Inlerbank # -~-- Expiration date 


Signature 


l oll free subscription numbers 800-258-5473 or 

800 - 251-6771 


1/77 


kilobaud 


PETER bo ROIXjll Nil 07458 
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I've heard several good comments regarding the SWTP printer since its introduction several months ago, and it looks like Denis 
Bourdeau is staying with that fine in his article on the PR-40. His approach is quite objective and he does a good job of pointing 
out the good (mostly! and the bad. Should be of interest to anyone thinking of buying one and I'm sure the points Denis makes 
would apply to similar printers, also r — John. 


How to Use 


the New PR-40 Printer 


available 5/16" ribbon. 
(SWTPC says that they have 
extra ribbons. Also, 5/16" 
typewriter ribbon is available 
at office supply stores, I'm 
not crazy about the purple 
color of the SWTPC ribbons, 
but this is almost surely due 
to a prejudice originating 
from the experience of 
looking at grocery receipts. 
Note, however, that the rib¬ 
bon can be turned over and 
that the paper width fits 
nicely on SV? by 11" paper.) 


When you see the PR-40 
close-up and in action you 
will probably share my reac¬ 
tion: "Hmmm, looks cheaper 
than I expected. But look at 
how the printer-head works 
.. . and how the ribbon auto¬ 
matically reverses . . . and 
how the driving cam works 
. . . so few moving parts . . . 
reliable . . , hmmm, very 
clever! Yeah, should last a 
long time!" 

The major reason that this 


Deals R- Bourdeau 
7700 West Glasgow PL 
B/dg. 22, Unit 3 
L it tie ton CO 80 J 23 


C ommunicating with a 
computer is difficult 
enough without having to 
agonize over the purchase of 
peripherals. There isn't a sin¬ 
gle micro-mini-computer 
owner that wouldn't want a 
line-pi inter, disk-drive, and 



Fig. 1. Electrical Interfacing. 


video terminal. Those who do 
not have eidetic memories of 
indefinite capacity are most 
likely to be very desirous of 
owning a hard-copy device. In 
particular, line-printers are 
very popular with software 
development types. In res¬ 
ponse to this demand. South 
west Technical Products Cor¬ 
poration has made available a 
practical line-printer for the 
hobbyist - the PR-40. Having 
purchased and assembled this 
printer, I would like to de¬ 
scribe my experience with it. 

Features 

Without a doubt, the most 
pertinent specification the 
printer possesses is its cost — 
$250, When one discovers 
that the PR40 only prints 40 
columns, the price somehow 
increases in impact. It wasn't 
until i realized how well it 
was designed that its purchase 
was easily justified. A dot¬ 
matrix, 75 line/minute 


printer possessing the 64 
character ASCII subset ought 
to raise your eyebrows. Upon 
discovering that this printer 
also contained a 40 character 
line-buffer, i was impressed. 
The presence of a line-buffer 
means two important things: 

1. The P R40 can accept data 
fast (one character per 
micro-second), and 

2. the driving computer can 
perform other functions 
wh \ le the line is being 
printed. (HI get into hand¬ 
shaking in a bit.) 

The PR-40 uses 3-7/8" 
adding machine paper which 
has the advantage of being 
common and cheap. Since a 
tractor-feed is not used, regis¬ 
tration of special forms will 
be a problem. An ordinary 
typewriter type platen is used 
with perfectly adequate paper 
feed. Two other similarities 
to a typewriter are the plat¬ 
en/paper pressure relief lever 
for repositioning the paper 
and the use of a scarce but 
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device is not considerably 
more expensive is the design 
of the cylindrical cam which 
drives the print-head. A tele¬ 
type such as the ASR 33 
responds to carriage-return 
and line-feed codes by return¬ 
ing the carriage and feeding 
lines. This is not the case with 
the PR-40. The cam is a 
cylinder grooved so that a 
tooth attached to the print¬ 
head drives the head from 
side to side as the cam ro¬ 
tates* The carriage-return 
code causes the line currently 
in the buffer to be printed 
when the cam rotation is 
underway* Thus no matter 
how many characters are to 
be printed, one rotation per 
line is required (that is 75 
rotations per minute.) 

-- PR-40 CHARACTER $£T —— 

• •wm'u—*-. :. <■>? 

MBCDEF&H IJ KUWWSSTUVWV2 V\ 11 

!*K*r 0**J - /K234K7SS , C*>? 

frecDtTQH I Ji<uir<0Pt3RSTi(vnfii vz [ \ 3 1 

1 "Hu* o**i : i 

MBCDEFGH IJKL l\ 31 

‘ C)*+, - 

kecwtch i joj»iop«sivvttcvz t\it 
Fig. 2. Character Set * 

Thus we see that South¬ 
west T echnical Products' 
PR-40 is an excellent com¬ 
promise between speed and 
line length. Twice as many 
characters per line would 
slow it down intolerably (if 
you find teletypes doubly 
intolerable) and a true line¬ 
feed and carriage-return 
action would increase the 
cost to more than many 
would want to pay. Since the 
majority of my efforts are 
directed toward systems soft¬ 
ware development, 32 char¬ 
acters per line {on my video 
terminal} suits me about as 
well as 40 characters. One of 
my maxims is that there is 
always an application that 
illustrates an exception to 
any software-related rule. The 
author therefore has per¬ 
formed a significant amount 
of development with the 
exceptional PR-40. 

In an effort to remain 
objective, it must be men¬ 


tioned that one item concerns 
me: The check-out instruc¬ 
tions caution one to not 
operate the printer for more 
than a minute or so if print¬ 
ing full lines* The reason 
given for this caution is a 
good one. In such a situation 
the 5 by 7 dot-matrix print¬ 
head solenoids tend to over¬ 
heat* They are being pulsed 
with a hefty 40 Vdc* The 
instructions also specify the 
conditions which minimize 
this heating* A pot controls 
the solenoid timer so that if 
400 microsecond "on" dura¬ 
tion is achieved the best 
compromise between faint 
lines and overheating will lie 
obtained* Since my scope 
does not do so well in mea¬ 
surements of time much less 
than milliseconds, I experi¬ 
mented with the adjustment 
until an easily read contrast 
occurred without unreason¬ 
able heating. This rough 
calibration was quick and 
simple due to the fact that 
one can easily access the 
intensity adjustment during 
the printing process. Even so, 
it is advised that those con¬ 
sidering using this machine 
err on the light side of print 
intensity* 

— s#mE ftssEiffiLEE secret 
tPSIWED 6ft T>£ f*M&> 

j 

-SUOROUTItC PRO* TRftCSttITS THE 
i CHFtfftCTER IN T>C A-REGISTEF TO 
i T>£ PRINTER KFFEP 

1T>C COLLINS ROUTINE MILL SUPPLY 
CPRPfllSt-RETURN <£iS> TO 
r START PRINTING n£ RFFER 

j 

<t>€ nsa or the ^register 

, MJST et SET TOR ALL OtfffiCTERS 
, RE PPOPtP PRINTER STROKING) 

J 

prop Out, m? .fton to fcpt 7 
>TOGGLE rtSB 

OUT, m? iMTfHXttY LOU 
#TOGGLE 6fltt W 

DVT-Mr iOrtTfi-REflOV HIGH 
* DflRACTER HAS JUST BEEN STORED 
, IN F*-4» lUFFEP 

!lrit for DATA-ACCEPTED Lite TO 
,00 HIGH tWST UNIT THE 

-ACTUAL PRINTING CP Tte LlteS 

i 

MBIT HtW; >DBTA-flCCEPTE£ IS 

RftC i USE OF PORT 2 

m wait .loop eecK 

RET i CO£, RETURN 

Fig. 3* Sample Program 
Printout * 

There is one additional 
aspect to the mechanics of 
the PR-40 that deserves 
mention* At 75 lines/minute, 
each line of forty characters 
is zapped out at such a rate 
that a fair amount of noise is 
produced. The most danger¬ 


ous effect of this noise is 
experienced when a cat is 
held near the printer just 
before it is started up. Yup, 
scares the h--l out of cats and 
t have long, straight scratches 
to prove it! 

A very nice feature of the 
ASCII character generator 
electronics is the conversion 
of small letters {octal 141 
through 172} to capital let¬ 
ters. This really means that 
the electronics ignore the bit 
which, if set in the code for a 
capital, produces the small 


letter. Speaking of codes, a 
carriage return (CR) is a 
sacred character. Upon 
receipt of a CR the elec¬ 
tronics initiates printing of 
the current line in the buffer 
and indicates to the interface 
that it is busy* A line-feed, as 
well as the other ASCII con¬ 
trol characters are ignored — 
they don't even get into the 
buffer* With the Digital 
Group parallel interface card 
one can use seven lines for 
the ASCI I codes and the MSB 
(8th) line for the "Data 


PR-40 CHARACTER SET 
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Close-up of print-head, cylindrical cam, and character set * 
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Ready' 1 strobe to the printer. 
With the addition of two 
more wires, the "Data 
Accepted" line monitored by 
the driving software, and a 
ground, the interface is 
complete. Note that some bit 
of some input port (parallel) 
must be used to monitor the 
''Data Accepted" control 
line* The Digital Group Sys¬ 
tem often has extra intuit 
port bits available. 

Interface Software (i.e., the 
"drive") 

The hand shaking is simple 
and easy to code. The control 
lines are normally high and go 
low when active. SWTPC 
supplies a test program writ¬ 
ten for their 680 system. My 
8080 system software devel¬ 
oped out of a bit of experi- 
mentation and a lot of reread¬ 
ing of the single paragraph 
explaining the hand-shaking. 
Since few microprocessors 
can output data in parallel 


faster than once per micro¬ 
second, the transfer of data 
to the printer buffer occurs as 
rapidly as the software can be 
executed. You will only have 
to wait for the tine to be 
printed — that is, if you have 
nothing else your software 
could be doing. If you do 
have other things going on r 
just be sure to check the 
"Data Accepted" line when 
reentering the printer driver* 
The software involved in 
interfacing the printer is not 
very involved. At the lowest 
level, where the actual out¬ 
put instructions occur, the 
following sequence drives the 
parallel interface: 

1. output the current char¬ 
acter with the MSB set; 

2* reset the MSB in the A 
register (use an oxclusive-or- 
i immediate); 

3. output this result; 

4* again toggle the MSB to 
complete strobing the printer 
logic (as in step 2); 


5. output character; 

6. enter a wait loop by first 
inputing from the port con¬ 
nected to the "Data Ac¬ 
cepted" line; 

7. check the corresponding 
bit (use the MSB or the LSB 
to allow a simple shift for 
testing carry bit); 

8. loop back to step 6 until 
line goes high indicating 

9. a return to calling routine. 

The wa it-loop is not 
exercised until the printer 
actually begins printing. You 
will notice that execution will 
fell through the wait-loop 
during transmission of the 
individual characters. This is 
due to the fact that the 
printer electronics have had 
more than enough time to 
stuff the character into the 
first -in-first-out buffer during 
steps 1 through 5, At higher 
levels, in the routines that call 
the described instructions, it 
is convenient to perform such 
functions as checking for 
character validity, translating 
linefeed (LF) and similar 
codes into CRs, and so on. In 
my Digital Group 8080 Sys¬ 
tem, the operating system 
contains logic on a higher 
level yet which allows edited 
source information to be 
printed. In addition, it is very 
useful to dump memory, 
symbol tables, traces, simula¬ 
tions and so on to the printer. 
In fact, this article was 
drafted and edited with the 
use of the PR-40. This printer 
is serving a valuable function 
in connection with some 
elementary word processing. 
My word processing program 
simply columnarizes text to 
average 46 columns in width. 
Ii also makes a wild stab at 
hyphenation when it fails to 
find a blank to serve as the 
end of the line* In this way, 
articles can be typed directly 
from the PR-40 listings! 

If you have a 32 char¬ 
acter/line CRT terminal, you 
will find that 32 characters is 
quite adequate for software 
development purposes and 
that some commonality 
between CRT and printer I/O 
can be efficiently achieved! 

Construction of the PR-40 


is described fairly well in the 
supplied documentation. I 
must warn those who do not 
have a fair amount of pre¬ 
vious experience with digital 
electronics assembly to be 
prepared to put in quite a few 
hours* You may even want to 
get some help. In my case, 
with a good deal of experi¬ 
ence, it still took 20 hours to 
assemble the PR-40. One area 
of particular difficulty was 
the construction of the four 
main moJex connectors* Not 
all of the connectors mated as 
snugly and as positively as 
they should have. This is a 
prime area for some innova¬ 
tion by using the individual 
connector pins rather than 
the nylon connector blocks. 
Some good heat-shrinkable 
tubing would allow the two 
J1 connectors to be simpli¬ 
fied to pin-to-pin hook-ups* 
Only one connector had a 
real propensity for easily 
wiggling back out, so this is 
not a major concern. The 
connector blocks significantly 
reduce certain wiring errors, 
however. 

An important piece of 
advice: This printer is com¬ 
plex enough to justify 
double-checking, triple¬ 
checking, and cross- and side¬ 
ways checking! 

The smoke-test is not a 
recommended method for 
checkout of this printer. The 
instructions specifically 
stipulate a testing procedure. 
This procedure is not com¬ 
plicated and will allow one to 
detect an error which could 
cause damage to the print- 
head. Essentially, measure¬ 
ment of the voltages fed to 
the print-head solenoids is 
required. 

The second phase of 
checkout consists of adjusting 
the intensity and line-width 
trimmers. Should problems 
arise, you are on your own 
because SWTPC does not try 
to provide a comprehensive 
list of the most likely prob¬ 
lems end the corresponding 
fixes. In fact, SWTPC says 
this, "In case of problems, 
the best procedure is to 
remove power and recheck all 



Inside chassis — note interconnecting cables and print head 
solenoid driver transistors. 
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assembly steps/* One can 
obtain repair services from 
SWTPC, but any experienced 
kit-builder knows that the 
number of problems are 
inversely proportional to the 
care (double- and triple¬ 
checking) taken during assem¬ 
bly, My printer worked the 
first time, as did every other 
SWTPC kit I've ever ordered 
and built. In anticipation of 
maintenance, however, 
sockets were purchased for all 
of the lC f s. Purchasing 
sockets for at least the larger. 


more expensive chips is 
highly recommended. 

Lastly, with respect to 
checkout and use of the 
PR-40, the documentation 
contains an excellent explana¬ 
tion of the operation of both 
the printer mechanics and 
electronics. If the builder can 
program even a little bit, he 
can fairly quickly write the 
software interface and a rou¬ 
tine to repeatedly generate 
the 64 ASCII characters for 
testing. The author spent a 
lot more time building than 


in interfacing — a ratio of 
about 5-to-1 to be precise. 

Conclusion 

The PR-40 was found to 
be unsuitable for special 
forms such as mailing labels. 
There is too little space 
between the print-head and 
platen for more than just the 
ribbon and a single layer of 
paper to occupy. Unfortu¬ 
nately, there aren't any 
adjustments possible which 
would permit the use of 
labels, multi-part forms, and 


the like. While it seems that a 
tractor-feed could be incorpo¬ 
rated into the design, my 
feeling is that this would 
require a number of asso¬ 
ciated design changes which 
would be like putting land¬ 
ing-gear on a VW H 

Those serious hobbyists, 
who may be constrained by 
money, space, and time — but 
certainly not ideas, should 
find that this microminia¬ 
turized hard-copy device will 
have a very significant effect 
on their productivity.® 



LIGHT' 


WESTON 4449 
Digital Multimeter 


FAST-' 

DEPENDABLE/ 


$ 149 . 

3 'A digit. Solid state. Dual slope high impedance bi-polar 
A/D converter. Auto-blanking and polarity. Single chip for 
logic circuitry. Overload protection. Ranges: DC Volts; 
0-199.9 mV - 1.999 V, .05% rdg ±1 digit. 0-19.99 - 
199.9-1000 V, .1% rdg ±1 digit. AC Volts: 0-99.9 mV - 

1.999- 19.99-199.9 V, ,3% rdg ±1 digit. 40 Hz - 10 kHz. 
0-1000 V .5% rdg ±1 digit, 40 Hz - 2 kHz. 199.9 mV - 

1.999- 19.99-199.9 V, .6% rdg ±1 digit, 10 kHz - 20 kHz, 
0-1000 V, 1% rdg ±1 digit, 2 kHz - 10 kHz. DC Current: 
0-199.9 uA — 1,999 mA, .2% rdg ±1 digit. AC Current: 
0-99.9 uA, .4% rdg ±1 digit, 40 Hz - 10 kHz. 0-1999 mA, 



.75% rdg +1 digit, 10 kHz - 20 kHz. Resistance: 0-199.90 
- 1.999 K, 1 mA @0.2 + 2 V, .25% rdg ±3 digits. 0-19.99 
K - 199,9 K, 10 uA @0.2 + 2 V..1%rdg±1 digit. 0-1.999 
M, 1 uA @ 2 V, .2% rdg ±1 digit. 0-19.99 M, .1 uA @ 2 V, 
.5% rdg ±1 digit. Specifications: Conversion Rate: 4 per sec. 
CMR: 80 dB. NWR: 38 dB. Power Req: 115 V, 50 - 400 
Hz. Temp: 25°C 3°C, 0° C-50 c C at derated acc. Size: 
2.25"H x 5.45''W x 7"0. Weight: Th lbs. 
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John Craig 
Editor 


Fire! 

... let your micro call for help 


T his started out as an 
article dealing with the 
construction and use of single 
board kits (microprocessor- 
on-a-board) being offered by 
several manufacturers to the 
commercial and hobbyist 
community. Because of the 
1 'do-nothing" state these 
boards seem to be in after 
construction, I decided to put 
one to use in a demonstra¬ 
tion of interrupts, interrupt 
operation is going to become 
more and more important as 
we become more and more 
sophisticated with our per¬ 
sonal computer systems; so if 
you're not familiar with their 
operation, let me suggest you 
come along for the ride! 

The Single Board System — ts 
It for You? 

There are a number of 
these boards available to the 
hobbyist today . , . and the 
number keeps growing. The 
[VI P U (Microprocessing 
Unit}-on a-board has, in most 
cases, been developed for two 
primary reasons. First of all, 
they can aff be used as part of 
a system .., either as a 
complete microcomputer 
system or as a dedicated con¬ 
troller (some with more 
effort than others). Secondly, 
several of these boards were 
designed and built with the 
objective of familiarizing the 
technician, engineer, or 
hobbyist with microcomputer 
technology, programming, 
and applications. The com¬ 
pleted board provides the 
hobbyist (or engineer) with 
the opportunity to learn 
machine-language program¬ 
ming. Machine-language is, 
without a doubt, the least 
efficient . . , but, in some 
applications (such as the 
dedicated controller) a small 


machine-language program 
may be all that is needed. 

Regarding the first applica¬ 
tion ... there's no reason 
why you [the hobbyist) 
couldn't use one of these 
boards as the building block 
for creating a complete 
microcomputer. This could 
include a cabinet with front 
pane] switches and indicators 
(and/or keyboard and display 
already on the board) along 
with a complete I/O system 
for interfacing with periph¬ 
erals. (Although such an 
undertaking probably 
shouldn't be taken on by the 
newcomer f) 

Regardless of whether the 
MPU-on-a-board is to be used 
as part of a complete system, 
or as a training device, the 
fact remains that you still 
have only an MPU when the 
board is finished. You should 
be prepared for a slight pang 
of disappointment when, 
after slaving over the con¬ 
struction of said board, you 
apply power for the first 
time. (I didn't have the radio 
on ... but in the background 
I could hear Peggy Lee sing¬ 
ing, "Is that all there is?") it's 


doubtful there are many 
things as dull as a computer 
what don't got no periph¬ 
erals! They have a habit of 
just sitting there and not 
doing much. But then, they 
aren't expected to do much 
. . . after all, it is just the 
MPU, 

One board I built recently 
had a cute (?) little counting 
program to demonstrate the 
operation of the board. The 
program outputs to the 
double digit display a count 
sequence (in decimal, even) 
from zero to 99. You can 
make it count faster ... or 
make it count slower ... or, 
if you're in the mood for a 
lot of variety, you can make 
it count slow and fast. 

Let's face it . . . the real 
fun with a computer begins 
when you put in a worth¬ 
while program and make it 
start doing something. 
Actually, the mechanics of 
entering a program is kind of 
a kick . . . whether it be from 
a cassette/paper tape, TTY, 
TVT, or any other input 
device. And of course, getting 
a print-out on some kind of 
output device is something 
we all desire, too. With most 


of these boards, the input 
device is a hexadecimal or 
octal keyboard with several 
command keys. The output 
device usually consists of two 
or more indicators for dis¬ 
playing the hex or octal 
digits. 

Now ... perhaps this has 
all sounded somewhat nega¬ 
tive up to this point. (In 
other words . . . you've only 
got this, but it would sure he 
neat to have all that!} Not so. 
One of the real challenges for 
the hardware types in this 
hobby is the interfacing of 
different devices to the com¬ 
puter, And, you've certainly 
got the opportunity to meet 
that challenge with one of 
these boards. So . . . winy not 
start with a MPU, a monitor 
program, some RAM, an 
input and an output port . . . 
and take it from there? 

The board I mentioned a 
moment ago uses the MOS 
Technology 6502 processor 
chip. I'd like to keep the 
following discussion in a 
genera! direction, rather than 
get into specifics, so we're 
going to use this 6502-based 
board as a typical MPU-on-a- 
board system (and the word 


108 


''system" is being used 
loosely here}. 

The construction of the 
board was a breeze. As a 
mailer of fact, the only 
problem encountered was 
when it came time to plug the 
6502 MPU chip into its 
socket- It's a 40-pin package 
*,. and all 40 pins were a 
bear to get in! But, once that 
was accomplished and the 
initial power was applied (+5 
V and -9 V), it sprang to life 
with vim and vigor! (Actu¬ 
ally, it just sat there ,, . but, 
at least it didn't smoke.) 
{Note: After installing the 1C 
sockets and cleaning the 
board, I made a good visual 
inspection to ensure there 
weren't any solder bridges. 
Then I applied power to the 
empty board (i.e., no ICs) as 
a further check against 
shorts.) 

The Hardware and Software 

The MOS Technology 
hardware and software manu¬ 
als supplied with the board 
furnished me with the infor¬ 
mation I wanted when I went 
to it *. . but, 1 can't really 
give an evaluation of the 
programming manual because 
it was written for assembly- 
language programming (with 
virtually no machine-language 
examples . . . which is under¬ 
standable), The manual was 
written for a programmer 
who is going to he developing 
programs for the 6502 using 
the Resident Assembler or a 
Cross-Assembler {i.e., an 
assembler for the 6502 
mnemonics (symbolic code) 
which was written to be run 
on a different, and usually 
larger, computer). 

This particular board came 
with a monitor program (256 
bytes) in PROM with three 
additional sockets for adding 
more PROMS, The monitor 
program is for loading, exe¬ 
cuting, and displaying pro¬ 
grams in the 1K of RAM 
memory. A function I didn't 
care for in this monitor (and, 
which caused me to have a 
software bug) was the fact 
that when you enter an 
address into memory (16 bits 


— 4 hex digits) the feast 
significant portion is entered 
first. For example, if you 
wanted to put in a LOAD A 
from location FA05, the op 
code for the LOAD A (AD) 
would be entered . ,.. fol¬ 
lowed by entering "05" and 
then "FA". Tis a bit con¬ 
fusing. 

After loading in the 
demonstration program, I 
called in the wife and kids 
and said, "Look, there's a 
whole computer right there 
on that one board! It doesn't 
do much, except sit there and 
count . , , ah, but wait a 
minute , , , I can change this 
location (What's a location. 
Daddy?) and make the thing 
count slower or faster. Pretty 
neat, huh? Just think ,,. a 
whole computer on that one 
little board!" 

Well, 1 don't have to tell 
you just how impressed those 
folks were! (Actually, as you 
may have guessed, I'm still 
trying to convince myself just 
how impressed they were!} 
So . . . it was "back-to-the- 
old-drawing-board" time. If 
not for their benefit, I 
decided that at least for my 
own, I was going to make this 
thing do something besides sit 
there and count. 

Interrupts? 

In a rare flash of brilliance 
l came up with a very simple 
circuit for demonstrating an 
interrupt operation. I hap¬ 
pened to have (laying around 
in my junk box) a heat sensor 
which I'd never found a 
use for. With this ! built a 
circuit to generate an inter¬ 
rupt to the processor when 
this sensor was activated (by 
holding a match under it . . , 
i.e., a "flame detector"). 

An Interrupt Application 

I've heard the remark, "So 
what?," with regard to inter¬ 
rupts and the home com¬ 
puter. There are those that 
feel interrupt operation isn't 
going to be a big considera¬ 
tion with the home system, 
but I can assure you that as 
things get more and more 
sophisticated (which they 
will) interrupts will be used 


more and more. It's really a 
very efficient way of doing 
things. 

Let me illustrate this 
"efficiency." We can either 
have our computer sitting 
around waiting for a particu¬ 
lar input (i.e., an external 
event), or we can have it busy 
processing data and doing a 
number of other things and 
interrupt it when that exter¬ 
na! event occurs. Perhaps the 
most common example we 
could use would be our 
friend, the noisy Teletype 
machine (or, if you're lucky, 
you've got a friend who is a 
TVT), If we're running a 
program which depends on 
inputs from the TTY [or 
TVT) we can either have the 
processor sitting in a loop 
waiting for that input ... or 
we can have it doing other 
things and then interrupt it 
when a key is hit. {And, 
eventually the home com¬ 
puter will be doing other 
things besides running your 
one program.) The interrupt 
will force the processor to 
exit the program being exe¬ 
cuted at the end of the cur¬ 
rent instruction. From there 
it will go and execute a sub¬ 
routine for handling the inter¬ 
rupt (le., a check will be 
made to see which key was 
hit on the TTY , . . and what 
action, if any, is to be taken). 
After executing this subrou¬ 
tine a return will be made to 
the program which was inter¬ 
rupted, and execution of that 
program will continue (as 
though the interrupt had 
never occurred). 

Here's something else to 


consider with regard to inter¬ 
rupt operation. How many 
TV sets do you have in your 
home? If you're a typical 
American family you've got 
at least two. In the years to 
come we're going to find that 
one terminal for the com¬ 
puter isn't going to satisfy the 
demands made by your 
family. You're going to be 
wanting to work with it 
developing software, or what¬ 
ever, and someone else in the 
family will be wanting to run 
an educational game or 
accounting program. The 
answer, of course, will be to 
have two terminals . . , run¬ 
ning in a time-share mode. . . 
which will be based on inter¬ 
rupt operation. Think about 
it. (And, excuse the use of 
the word "work" up there 
., . very bad.) 

Now, if I've convinced you 
of the need to become famil¬ 
iar with, and use, interrupts 
(assuming the "convincing" 
was needed), let's get on with 
a discussion of an interrupt 
circuit and how it was imple¬ 
mented. 

Fig, 1 is a schematic of the 
Circuit which I built to 
demonstrate an interrupt 
using the board. The MOS 
TECHNOLOGY 6502 has 
two different interrupts. One 
is maskable through software 
(IRQ) and the other is a 
nonmaskable interrupt 
(NMI). The operational 
requirements for the IRQ 
were somewhat more strin¬ 
gent than the NMI ... so I 
went with the easier NMI. 
The nonmaskable interrupt is 
edge-sensitive and is simply 



Fig . 1. interrupt circuit schematic. 
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looking for a one-to-zero 
transition. 

When a match is held 
under the heat sensor it 
eventually reaches a certain 
temperature and the contacts 
close. This causes the MM I 
line to drop low. The pro¬ 
gram which was being exe¬ 
cuted is interrupted at the 
end of the current instruction 
and the processor then begins 
executing an '"interrupt 
handling" subroutine, tn this 
subroutine. Data Bit 0 is set 
to a 1 and sent out to the 
Data Bus Output Latch, (This 
is accomplished simply by 
storing a word — with bit 0 
set — in memory location 
F900, which is dedicated to 
DATA OUTPUT OPERA¬ 
TIONS,! As a result of storing 
the word in this particular 
location a clock pulse for the 
Output Latch is generated, 
and the 1 is clocked into bit 0 


of the latch. The Output 
Latch being in a set condition 
generates a Direct Set to the 
external alarm flip-flop. This, 
in turn, activates an LED 
which is the alarm, (The LED 
is used to provide an indica¬ 
tion that the interrupt 
handling subroutine had been 
executed. Naturally, it 
wouldn't make a very good 
fire alarm!) Sending a t to 
the Output Latch is followed 
(in the subroutine) by out- 
putting a 0 ... so the latch 
will not remain in a set con¬ 
dition. This allows me to 
reset the alarm flip-flop using 
the switch coming in on the 
Direct Clear input. (I haven't 
provided pin numbers and 
parts identification on this 
schematic because it is of 
such a specialized nature . . . 
and 1 doubt that anyone will 
be building one.) 

Fig. 2 is a block diagram 



Demonstrating the flame detection circuit 


of the software involved in 
this operation. As I men¬ 
tioned earlier, the board came 
with a demonstration pro¬ 
gram which counted from 
zero to ninety-nine. 1 used 
this program as the executive, 
or main program, which was 
to be interrupted. 

Upon recognizing the 
interrupt, the Program 
Counter is pushed onto the 
stack, and then the processor 
takes the contents of location 
FFFA {which contains 0003) 
and places that value in the 
Program Counter. (Location 
FFFA is referred to by the 
programming manual as a 
vector pointer because it is 
used to point to the actual 
interrupt subroutine address.) 
The Program Counter (PC) 
now contains 0003, and the 
JUMP instruction in that 
location is fetched and exe¬ 
cuted. The JUMP is to loca¬ 
tion 300, which is the begin¬ 
ning of the Interrupt Han¬ 
dling Subroutine, (The jump 
to 300 is part of the program¬ 
ming which you, the pro¬ 
grammer, must do. The 
previous steps arc done 
automatically by the pro 


cessor , .. and the "0003" 
value is a result of the moni¬ 
tor program.) 

The first item of business 
in the Interrupt Handling 
Subroutine is saving the A 
Register by pushing it onto 
the stack (because it was 
being used in the counting 
program). Then a 1 and a 0 
are stored into location F900 
(DATA OUTPUT location). 
The alarm flip-flop is set. and 
the alarm LED is lit. Then, 
the A register value is pulled 
off of the stack and restored 
into the A register. The last 
instruction in this routine is a 
Return from Interrupt (RTI) 
and its function is to restore 
the Program Counter {using 
the value pushed onto the 
stack in the very beginning, 
that is, the address of the 
next instruction to be exe¬ 
cuted in the program which 
was interrupted). The instruc¬ 
tion at that location is 
fetched and executed ,,,and 
the main program resumes as 
though nothing happened. 

Naturally, after building 
this fantastic circuit I just had 
to demonstrate it for some¬ 
one . . . anyone! You can see 
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All parts are BRAND NEW PRIME UNITS 
unless otherwise specified. Some are limited 
quantities. These prices are effective ONLY 
thru December 31, 1976. 

BRAND NEW PRODUCT FROM SUN- 
TRONIX. Did you ever wonder how the pros 
were able to etch a complicated PC board 
with such outstanding results? Do you want 
to be able to etch a HI-DENSITY PC board 
and still keep all those FINE traces intact? 
The secret is in the type of etching equipment 
used. BUBBLE ETCHERS are many times 
superior to hand agitated trays or tanks — 
better than most spray etchers and inferior to 
none. We are now manufacturing a line of 


# • • *• • 

CHRISTMAS 
PARTS SALS 


BUBBLE ETCHERS that are of first class 
quality, designed with the hobby and semi- 
professional application in mind, and VERY 
INEXPENSIVE. We offer several models of 
basic ETCHERS as well as a wide range of 
accessories, such as PC card holders, air 
pumps, plumbing, immersion heaters, etc. 
Prices start at S69.95 for our unheated model, 
which includes one PC card holder. Please 
write for more information. 


• PC BOARD STOCK. First grade 
epoxy glass 1/16" cut to your size 
for only $0.02 per square inch, single 
sided. Double sided $0,035 per 
square inch. 

• IMMERSION TIN PLATE SOLD- 
TION. For professional PC boards 
you must tin plate them. Enhances 
sotderability and appearance. 1 q,t, 
will plate dozens of average size PC 
boards. No fuss, no muss — dunk 'em 
and out come bright shiny easy to 
solder PC boards. Instr. inch 
$B,95/qt. 

• VIATRQN SYSTEM 21 {BRAND 
NEW UNITS!, Checked out and oper¬ 
able, but sold as-is. Only 5 left so act 
fast. Shipped freight collect for 
ONLY $295,00. {Check previous ads 
of our competitors and be 
AMAZED.) 


•COPPER ETCH CRYSTALS. Dry 
powder mixed with water forms a 
very fast and safe copper etch solu¬ 
tion. Easy to dispose of when ox- 
hausted. Enough to make three gal¬ 
lons of etch, 5 lbs, S4.95 ea. 

• PC BOARD PROJECT KIT, This 
kit includes an assortment of single 
and double sided PC stock in useable 
sizes, plus one pint of immersion tin 
plate solution and five pounds of 
etch. Instr. included. $14,95 ea. 

• MULTI VOLTAGE REGULATOR 
CARD, Removed from functioning 
power supplies and guaranteed. Com. 
plete regulator for M5, -15 and i5 
volts. Currents in excess of 3,0 Amps. 
You supply the raw dc voltages and a 
case; we supply the rest, including 
the pass transistors good for 10.0 
Amps. Schematic included. $14.95. 


• COPPER CLEANER SOLUTION, 
Immersion removes soil and oiL 
$5,95/qt. 

• FLAT RIBBON WIRE. 20 conduc¬ 
tor ^28 Ribbon at give-away prices. 
$0.39/ft. Min. order, 10 ft. 


• TRANSISTORS 

2N3859 Equiv. NPN S .20 

TIS93 PNP .49 

TIS98 NPN .59 

MPS2222A NPN .20 

MPS2907A PNP .20 

• LINEAR 

709 Op Amp TO-5 $ .20 

301 AN DIP .49 

DATEL IC8B DAC 9,95 

LM3Q9K TO-3 1,49 

NE555 OJP .50 

LM50QQ Reg 4.95 


• UART. COM2502/2Q17 40 pin DIP UNTESTED. S3.95, 
But the ones weVe checked work fine at 4.5 volts instead of 
5.0, 


We also stock an In-depth line of 7400 series TTL, including CMOS. Please inquire as to availability and price. 
Video Display Terminal subassemblies and Keyboards are still available, bur the supply is dwindling. Graphics 
Drivers are In full production and available from stock. Please see our ads in August and September 73 for 
details. 



TERMS' Full cash price, plus shipping costs MUST be included with order. We accept MasterCharge and 
BankAmericard. Please, NO CODs. Excess shipping payments refunded promptly. Prices and availabilities 
subject to change without notice. NO EXPORTS. 

mmnr, 

360 Merrimack Street, Lawrence MA 01843 617-688-0751 
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this actual, true-to-life 
demonstration being per¬ 
formed for my daughter Sheri 
in the photo. Light the match 
... hold it under the sensor 
... watch the LED come on 
... and the processor never 
misses a beat in its counting 
routine. Thrilling! (I jabbed 
her in the ribs a moment after 
that picture was taken ... 
and found that she was sound 
asleep!) 

A Practical Fire-Detection 
System 

The circuit described in 
the previous section is just 
fine and dandy as an example 
of how an interrupt works 
using a heat-detection circuit. 
But, it certainly has some 
serious drawbacks as a practi¬ 
cal fire-detection circuit. First 
of all, the computer is instru¬ 
mental in setting off the 
alarm in the flame detection 
circuit. I think that would be 
a mistake. As much as I love 
and respect my computer, I 
wouldn't want it to be 
responsible for saving my life! 
I have two very good smoke 
detectors installed in my 
home which set off a very 
loud alarm when smoke is 
detected. (This is, of course, 
the other obvious short¬ 
coming of my teat-detecting 
circuit.. . smoke detection is 
the only way to go.) The 
smoke detectors work off of 
batteries which is another 
advantage, because there is 
always the chance that the 
fire might be started from an 
electrical overload or short. 


which might be on the same 
circuit as the computer... ! 
Also, with regard to the 
computer, it would be just 
my luck that it would get 
hung up in a loop (the wrong 
one) on the night my house 
decided to bum down. 
(Although it might not be a 
bad idea to have the com¬ 
puter monitor the batteries in 
the smoke detectors and 
sound an alarm if they get 
too low.) 

I think the most practical 
part the computer could play 
in a fire-detection system 
would be to call the fire 
department and alert them to 
the fact that you have a fire 
in your home. Fig. 3 is a 
block diagram of my pro¬ 
posed system. 

Before we get into a dis¬ 
cussion of the hardware and 
how it could be implemented, 
let's take a look at the situa¬ 
tion. In other words, let's see 
if we can examine your 
thoughts and actions if you 
were suddenly awakened in 
the middle of the night by an 
alarm from a smoke detector. 
Your first two immediate 
concerns would be getting 
your family and yourself out 
of the house and finding out 
where the fire is. It's rather 
doubtful that you would 
want (or, in many cases, be 
able) to stop and phone the 
fire department. I personally 
would want to get to that 
garden hose and start doing 
what I could to stop the fire. 

You could run to a neigh¬ 
bor's house (or send your 


wife, if ya got one) to call the 
fire department. But , the 
beauty (?) of my proposed 
system is that the fire depart¬ 
ment would be notified and 
probably on their way by the 
time you get out of your 
bedroom! Those first few 
minutes can certainly be 
important ones, too. The big 
factor to consider is this: 
How long can you hold your 
breath? It's smoke inhalation 
that kills people. If a member 
of your family has been 
overcome by smoke, then the 
minutes it takes the fire 
department and their oxygen 
to arrive may mean the differ¬ 
ence between life and death. 

Another feature which I 
consider important would be 
to have a separate audio 
alarm (perhaps a bell ... 
something different from the 
smoke detector's) which 
would tell you that the com¬ 
puter had successfully con¬ 
tacted the fire department 
and that they acknowledged 
and were on the way. If you 
heard this alarm you could go 
ahead and do what you could 
to fight the fire, comfortable 
in the knowledge they were 
coming. On the other hand, if 
you didn't hear it you would 
know that a call was still 
needed. 

The hardware for imple¬ 
menting such a system as this 
is available. We're not talking 
about a wild dream .. . just 
something that would very 
likely be quite a hassle to 
build and implement! In the 
block diagram you'll notice 
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Fig. 3. Block diagram of a practical fire detection system. 


that I left the smoke detector 
intact and simply brought out 
the signal which sounds the 
alarm. This signal will be used 
to generate an interrupt to 
the computer (which will be f 
running in the executive, or 
main program, of your Home / 
Operating System). 

This interrupt signal will * 
be enabled to the processor 
by either a manual switch or , 
a timer. The switch will be 
thrown to the enable position 
if you're going to be away 
from the house for an 
extended period (day or 
night). For example, you 
could have the timer enable 
the interrupt signal only from 
9 pm to 7 am. This is done 
because the smoke detectors 
can sometimes be set off 
inadvertently by someone 
smoking underneath them. 
Therefore, it might be better 
to have the system off during 
the day to eliminate the 
possibility of false alarms 
(which the fire department 
certainly wouldn't appreciate 
... especially from a com¬ 
puter). Of course, this 
problem (of disabling during 
the day) could be eliminated 
by banning smoking in the 
house, right? On the other 
hand, maybe there's nobody 
around your house during the 
day. 

The timer circuit could 
actually be a software routine 
or, even better, a real-time 
clock in the computer. 

This is, of course, a trade¬ 
off decision which must be 
faced whenever either hard¬ 
ware or software is being 
designed. There are a lot of 
considerations. For example, 
is the computer going to be 
sitting in its timer software 
routine all the time, or will it 
be used for other chores as 
well as the timekeeping? 

Note that the interrupt 
signal is going into an Inter¬ 
rupt Priority Network. This 
circuit will allow you to have 
a number of interrupts from 
different sources (which will 
very likely be the configura¬ 
tion for the eventual home 
system). In this case the 
computer will either poll the 
interrupts to find out which 
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one is active or will use inter- 
rupts of the vector type. But, 
that's a subject for another 
article. (Anyone care to 
bite?) 

The heart of this system 
will be a program (and hard¬ 
ware} which will generate a 
digitized voice message once 
the fire department has 
answered the phone. (It 
would also be quite possible 
to use a regular portable 
cassette recorder * . . but, I 
would think it would then 
have to be dedicated to this 
application.) The sequence of 
events performed by the 
computer is depicted by the 
lines coming out, from top to 
bottom. (The sequence of 
events represents both hard¬ 
ware and software opera¬ 
tions.) After obtaining a dial 
tone the interface logic sends 
an acknowledge to the pro¬ 
cessor, which responds by 
initiating the touchtone 
dialing of the fire depart¬ 
ment's number. When the 
ringing stops (be., when the 
phone has been answered) the 
computer begins execution of 
the digitized voice message 


program . .. "This is a 
computer-generated message 
to inform you that a fire has 
broken out in the Smith 
residence which is located at 
501 Anchor Way. To repeat, 
this is a computer-generated 
message to inform you that a 
fire has broken out in the 
Smith residence which is 
located at 501 Anchor Way. 
If you acknowledge receipt of 
this message, please flash 
your receiver three times/' 
Logic which would detect 
these three flashes would 
generate an acknowledge 
signal back to the computer. 
The computer would in turn 
activate the "message 
received" alarm/indicators 
both inside and outside of the 
house. 

Without a doubt, were one 
to build a system such as this, 
it would be advisable to tell 
the local fire department 
about it . . . and perhaps even 
demonstrate it for them. 
Also, it's very likely that 
there are some considerations 
which I've overlooked. If you 
have any comments, I'd be 
interested in hearing them.® 



IN RESPONSE TO POPULAR DEMAND TSC HRS WRITTEN 
SEVERAL PROGRAMS FOR THE USERS OF 6502 BASED 
COMPUTER SYSTEMS. THIS PACKAGE CONTAINS FIVE 
CF OUR MOST POPULAR GRME PROGRAMS AND IS COM¬ 
PATIBLE WITH KIM» TIM, 0S1, AND JOLT MONITOR 
SYSTEMS WITH AN 1/0 TERMINAL* YOU GET EXCIT¬ 
ING VERSIONS OF HANGMAN. RCEY-DUCEY* SWITCH. 
MASTERMIND. HURKLE. AND EVEN A RANDOM NUMBER 
GENERATOR. All BOUND IN A HANDY BINDER. THIS 
ASSEMBLY LANGUAGE SOFTWARE PACKAGE INCLUDES 
COMPLETE USER DOCUMENTATION* YOU GET A COM¬ 
PLETE, NELL COMMENTED, ASSEMBLED SOURCE LIST¬ 
ING* INCLUDING A SORTED SYMBOL TABLE AND HEX 
CODE DUMP. INSTRUCTIONS FOR USE AND EVEN SAM¬ 
PLE OUTPUT* HOWEVER. NO PAPER TAPES OR CAS¬ 
SETTES ARE AVAILABLE AT THE PRESENT TIME* 
THTS PACKAGE TS EXACTLY WHAT YOU HAVE BEEN 
WAITING FOR. AND ITS ONLY $19,95. ORDER PDA 

BOAQ 

ATTENTION 8080 USERS, A PACKAGE SIMILAR TO 
■’’ME ONE DESCRIBED ABOVE KILL SCON BE RELEASED 
FOR 8080 MICROPROCESSORS. WATCH FOR OUR ROS. 

CflQQ 

NOTE T HRT TSC ALSO HAS OVER 20 PROGRAMS FOR 
6800 SYSTEMS NOW AVAILABLE. SEND $.25 FOR A 
COMPLETE SOFTWARE CATALOG. WHEN ORDERING. 
PLEASE INCLUDE 37. FOR POSTAGE. INDIANA RES¬ 
IDENTS ADD 47. SALES TAX. CHECKS WILL CLEAR. 


TECHNICAL SYSTEMS CONSULTANTS 

BOX £S7N H. LF^flYETTE INDIANA H79CE 



SwTPC 6800...$395 
ilMSAI 8080...$599 
ONE DAY 
SHIPMENT -A i| t 


WRITE FOR 
OUR CATALOG 
Dept. B 

584 Conmonwealth 
Boston, MA 02215 
"THE BIGGEST 
COMPUTER HOBBY 
CENTER IN THE 
WORLD" 


• 270 nsec Access Time • 470 nsec 
Read/Write Time • TTL Compatible Ad¬ 
dress Bus • Tri-State Data Bus Driver • 
Fully Socketed • Sphere Compatible • 
Easy Home Brew Interface* Voltages+12, 
+5, -5 • 


LOW COST 
MEMORY 
16K x 8 BIT 
DYNAMIC 
RAM 


Model Description Price 

WWW-16KA Fully Assembled $650.00 
WWW-16KK Kit $550.00 


WWW ENTERPRISES 
P.O. Box 548, 

Harbor City CA 90710 
(213) 835-9417 
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Robert Grater 
1595-21 Lauretwood Rd 
Santa Clara CA 95050 


A Teletype 
Alternative 


Almost every single-board computer we see these days was 
originally designed for the industrial community and snatched 
up by the hobbyists when and if the price got right Many of 
these boards have TTY interfaces, which, in most cases, are 
not too useful to the less affluent hobbyists. This is a shame, 
because that input and output are being wasted along with the 
routines in ROM for driving them. But, all is not lostI Bob 
Grater has the answer for using that TTY I/O ... the Serial 
Adaptor Board. This article should appeal to those of us with 
TV Typewriters (vs. video boards from Proc Tech, Digital 
Group, Polymorphic, etc.). If you build the board (from 
scratch) or purchase and interface it with a processor not 
mentioned in the article. I'm sure the manufacturer would 
appreciate a copy of your interface scheme to share with 
others. — John. 


A number of the new 
m i crocomputers now 
on the market are designed to 
fit the novice computer buff's 
pocketbook, teach him ma¬ 
chine language, and act as the 
basic CPU for an expandable 
system. Many of these micro¬ 
computers have serial TTY 
ports already on the main 
board Somehow this always 
seemed a bit inconsistent to 
me, since an ASR-33 will run 


the better part of a kilobuck, 
requires a good bit of main¬ 
tenance, and does strange 
things to domestic tranquility 
when operated at 4 am on a 
Sunday morning! Most of 
these m icrocomputer-on-a- 
board units were designed for 
commercial applications and 
the companies doing the 
development work can cer¬ 
tainly afford ASR-33 TTYs. 
Not so with the hobbyist! 



Serial Adaptor Board, Block Diagram 


The Serial Adaptor Board 
(SAB) described in this article 
won't help with the problem 
of acquiring an ASR-33, but 
it will allow accessing the 
TTY port on a micro¬ 
computer, therefore taking 
advantage of the routines 
already in ROM for TTY use. 
Too slow, you say! Not real¬ 
ly. KIM, for example, will run 
at 300 baud (and faster, but 
I'll stick to manufacturer's 
specifications) and SWTP 
6800 will go at 1200 baud 

The SAB-1 Serial Adaptor 
Board was designed to be as 
universal as possible when 
interfacing with a parallel TV 
typewriter to a computer 
serial TTY port. It features an 
adjustable on-board clock. 
Serial Data Out (SDO), not 
(indicated by o verbar) Serial 
Data Out (SDO ), Serial Data 
In (SDI), SD1, KS and KS 
Keystrobe Out to the TVT, 
and jumper selectable pro¬ 
gramming of the I/O plugs. 

The SAB-1 is built on a 3" 
X 3y 2 " PC board using a 
NE555 as a clock oscillator. 
Baud rates between 90 and 
460 are available within the 
range of the 20k trimpot 
Higher baud rates can be 
obtained by simply exchang¬ 
ing the 0.01 uF precision 
polystyrene capacitor for one 
of a smaller value. Also, an 
external clock may be used 
by lifting the jumper from 
pin #3 of the NE555 and 
running the external clock 
into the clock line. 


Parallel to serial data con¬ 
version is done via the AY-5- 
1013 (or similar) UART 
which is run in an asynchro¬ 
nous unconditional mode. 
The different data inversions 
available are accomplished by 
the CD-4049 CMOS Hex 
lnverter/T2L Converter (the 
outputs of which will drive 
two standard t2l loads). 

Power Requirements 

The +5 volt supply draws 
20 mA maximum in all cases, 
and the current requirement 
depends on the loads driven 
by the 4049. The +5 volts 
may enter the board at either 
J1 (TVT) or J2 (KYBD). The 
-12 volts is required only for 
the AY-5-1013 UART. If a 
AY-5-1014, 6402, or some 
other UART is used, the -12 
volts will probably not be 
required. The -12 volts enters 
the board at J1 (TVT). 
Extensive filtering is done on 
the board to ensure transient 
suppression. 

Keyboard Connections 
The keyboard interface 
(J2) requires data bits 1 
through 7 to be positive going 
and the keystrobe to be nega¬ 
tive going (KS). Pulse widths 
are not critical since the 
UART will accept them as 
they come along. If your 
particular keyboard has a 
positive going keystrobe and 
you are not using connections 
A and B on the board to 
invert SDI, you may invert 
KS in this inverter section. A 
positive KS in at point B will 
give you KS at point A, 
which ma y be tied to pin 2 of 
J2 for KS in. Bits 1 through 7 
are jumper selectable to pins 
9 through 16 of J2 (see con¬ 
struction section) depending 
on what configuration you 
wish. 

TVT Interface 

Data Out bits 1 through 7 
are jumpered to J1 pins 9 
through 16, again depending 
on the configuration you 
desire. The keystrobe is avail¬ 
able at pin 7 of J1, and may 
be either positive or negative 
going (KS or KS) depending 
on the jumper selection at KS 
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SEL. All power supply volt¬ 
ages are normally fed to the 
board via J1 since most TVTs 
have the -12 volts available. 
The +5 volts is run across the 
board with heavy bypassing 
so your keyboard may be 
powered directly from con¬ 
nector J2. 


Board Construction 

1. Normal PC board 
build-up procedures are used 
following the parts placement 
diagram*. Permanent jumpers 
(8 total) are installed at the 
points indicated by the 
arrows on the layout diagram. 
The jumper on J2 pins 3 r 4 
and 5 to ground is first run 
through one of these pin con¬ 
nection holes for the socket, 
then through the hole in the 
edge foil in the board 
(ground). 

2. Keystrobe Out SE¬ 
LECT: The KS output to the 
TVT is selectable; for a posi¬ 
tive going KS, the point 
marked SEL is jumpered to 
the point marked KS. For a 
negative KS, SEL is jumpered 
to the point above KS. 

3. Serial D ata Ou t SDO 
(U2 pin 2) and SDO (U2 pin 
4) are always available; either 
or both may be used for your 
system. 

4. Serial Data In: SOI is 
connected directly to the 
point marked SDL If SDI is 
required for your installation, 
point SDI is ju mper ed to 
point A, and the SDI signal 
enters at point B.** 

5. Data Bits: Data Bits are 
jumper selectable at both J1 
(TVT) and J2 (KYBD). Please 
note that UART (U1) pins 5 
and 33 are brought out to 
jumper select pads; ignore 
these as they are not con¬ 
nected internally in the 
UART. So only 7 of the 8 


* For Bay Area TVT, the socket at 
J1 is installed so that pins 9-16 
face the jumper pads from the 
UART(UI). 

**lf this inverter is not used to 
invert serial data in, it may be 
used to invert a positive incoming 
keystrobe by bringing the KS 
directly to point "B" and jumper¬ 
ing point "A" to pin 2 of J2. 


pins available on the UART 
side of both J1 and J2 are 
used. Data bit outputs from 
the UART are shown as fol¬ 
lows: 

TX Data to J1 
Bit UART Pin# 

1 12 

2 11 

3 10 

4 9 

5 8 

6 7 

7 66 

RX Data from J2 
Bit UART Pin # 

1 26 

2 27 

3 28 

4 29 

5 30 

6 31 

7 32 

6. Power: The board 
draws little power (20 mA @ 
5 volts and 5 mA @ -12 
volts); this is brought up via 
J1 from the TVT. The 5 volt 
line runs through to J2 with 
heavy bypassing so your key¬ 
board may be powered via 
this single plug. 

7. Clock Adjustment: The 
clock is available at pin 3 of 
the NE555 (U3). A counter is 
handy for setting it up but is 
not mandatory. With the 


components furnished, clock 
frequency is adjustable for 
baud rates between 90 and 
460. The baud rate may be 
determined by dividing the 


clock frequency by 16. Thus, 
110 baud (TTY) would be 
1760 Hz. For KIM, this is no 
problem since it is self-adjust¬ 
ing. If you don't have access 


Symbol 

Quantity 

Description 

U-1 

1 

General Instruments 

AY-5-1013 (or simi¬ 
lar) UART 

U-2 

1 

CD4049 Inverter Driver 

U-3 

1 

NE555 Timer 

R-1 

1 

4.7k, 1/4W Resistor 

R-2 

1 

56k, 1/4W Resistor 

R-3 

1 

Ik, 1/4W Resistor 

R-4 

1 

100k, 1/4W Resistor 

R-5 

1 

20k Trimpot 

D-1 

1 

1N914 Signal Diode 

C-1 

1 

0.01 uf Polystyrene 

C-2,-3 

2 

10 uf <a> 25V Tantalum 

C-4,-5,-6 

3 

0.01 uf ceramic disc 

Wise. Sockets 3 

1 

1 

16 Pin DIP sockets 
(J1, J2,&CD 1049) 

8 Pin DIP socket (for NE555) 
40 Pin DIP socket (for UART) 


SAB-1 Parts List 


J1 (TV Terminal) J2 (Keyboard) 


Pin 

Conn. 

Pin 

Conn. 

1 

N/C 

1 

N/C 

2 

N/C 

2 

Key Strobe 

3 

-12 volts 

3 

• (Gnd.) 

4 

N/C 

4 

- (Gnd.) 

5 

- (Gnd.) 

5 

-(Gnd.) 

6 

+5 volts 

6 

+5 volts 

7 

KS or KS 

7 

+5 volts 

8 

N/C 

8 

+5 volts 


Pinout listing for nonse/ectable pins 
onJI and J2 



***Do not install the jumper between the 555 (pin 3) and the UART clock line (UART pin 
40-17); instead, connect the clock line to the jumper at Cl-C0 of the MPC Board. 


Serial Adaptor Board , Schematic Diagram 
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Serial Adaptor Board, Component Layout 


to a counter, clocking into 
other systems requires a 
"turn and try" procedure. 
Adjust the pot until you get 
solid write-through, then go 
both ways until the data 
drops out, finally arriving at a 
center setting between these 
points/ 

Interfacing with KIM 

Interfacing with the TTY 
port on the KIM-1 is quite 
easy. It allows you to use the 
teletype routines already in 
ROM, including the TAPE 
DUMP which allows display 
of any series of memory loca¬ 
tions. Two Ik, Va W resistors 
and a SPST switch are 
required if you wish to select 
between your TVT and the 
KIM onboard display. 

On the SAB-1, point SDI 


* Higher or lower baud rates may 
be obtained by changing Cl, the 
0.01 uF polystyrene; but since 
the UART is being operated in an 
asynchronous, unconditional 
mode, rates above about 2K Baud 
are not recommended because of 
possible data loss. 


is jumpered to point A, then 
point B is run to pin A-U on 
the KIM applications con¬ 
nector. A Ik pull-up resistor 
is installed between pins A-U 
and A-S. Point SDO is run 
through a 1 k, !4 W resistor to 
pin A-T, and ground is 
brought from the edge foil on 
the SAB-1 to pin A-1. Pins 
A-21 and A-V may be per¬ 
manently jumpered to allow 
TVT operation, or a SPST 
switch installed to allow 
access to the on-board dis¬ 
play. 

With everything con¬ 
nected, press the RS (reset) 
button on the on-board key¬ 
board. This gets us back into 
the monitor program. Then 
type a RUB OUT (ASCII 
1111 1111) on your ASCII 
keyboard; the TVT should 
display KIM and some 
memory location. From there 
on in, follow the KIM manu¬ 
al. Unless your ASCII key¬ 
board is TTY oriented, it may 
not have a RUB OUT or 
DELETE character available 


— MOS says this is required 
to sense the baud rate. This 
isn't really a problem, as a 
question mark (?) (ASCII 
0111 1111) seems to work 
just as well (on my system, at 
least, KIM seems to be happy 
with it). The baud rate may 
be adjusted with the SAB-1 
clock adjust for 300 baud 
(4800 Hz) which is quite fast 
writing on the TVT, or you 
may experiment running it 
faster (it works) by running it 
up until KIM won't accept it. 
Remember: to let KIM find 
the new rate after an adjust¬ 
ment, you must hit RS, then 
RUB OUT or? on the ASCII 
keyboard. 

SWTP 6800 Interfacing 

A 2N2222 transistor and 3 
resistors are required to inter¬ 
face into the 6800 MP-C 
board. The SAB-1 clock 
should be adjusted with a 
counter to match the baud 
rate you have selected on the 
MP-C board. If a counter is 
not available, the twist and 
try method may be used, 
although it is a bit time con¬ 
suming. 

RS-232 

RS-232 interfacing using 
two MCT-2 Opto isolators is 
shown for anyone desiring to 
access a serial port on their 
IMSAI or MITS systems. 

Bay Area TVT 

The jumper connections 
on J1 for the Bay Area TVT 
are shown so that a male-to- 
male 16 pin DIP connector 
cable may be used between 
the TVT and the SAB-1. A 
source for the TVT is shown 


in the parts lists. 

A Word About UARTS 
These nifty little $erial-to- 
parallel data converters are 
just that, and more. It is 
worthwhile to take the time 
to read through a specifica¬ 
tion sheet; you'll get a world 
of information. The SAB-1 
uses the UART in an asyn¬ 
chronous, unconditional 
mode; that is, if it sees the 
proper start and stop bits on 
the serial data, it dumps it in 
parallel format, and vice 
versai There are probably a 
dozen other different modes 
in which it may be ordered, 
including synchronous with 
checks for framing error, 
parity, etc. So read the 
sheets, you may want to aim 
for that 30 kilobaud the 
manufacturer's specifications 
call out! 

Kits 

The SAB-1 is available as a 
complete kit, including 
sockets for all ICs @ $24.95 
postpaid, from: 

RGS Electronics 
3650 Charles St. (Suite K) 
Santa Clara CA 95050 

The Bay Area TVT is avail¬ 
able as a complete kit or bare 
board. It has ASCII keyboard 
input and direct video output 
and requires 5 V @ 1.25 A 
and -12 V @ 40 mA. Com¬ 
plete kit is $120 or bare 
board $35 plus postage and 
handling charge of $1, from: 

BYTE SHOP #2 
3400 W. El Camino Real 
Santa Clara CA 95051 



from page 90 

merits that would enable an EDP 
Center to gather information and then 
give the small businessman a daily 
readout of the status of his expected 
profit and loss. I noticed in today’s 
LA Times a firm offering a similar 
service. They call themselves 
PAYFONE. Daily figures are read in 
by remote terminal and PAYFONE 
completes the data processing. 


I am looking forward to the first 
issue of Kilobaud, I am sure it will be 
a success. 

Anthony J. Oreb, Jr. 
3700 Dean Dr., Apt 2607 
Ventura CA 93003 


It appears that the majority of people 
are interested in stand alone systems 
for their small businesses, rather than 
something like the PA YFONE you 
mention. That "EDP Center” will 
probably be sitting on a desk in a 
small businessman’s office, Tony. 
And, we’ll be sure and keep you up to 
date on new developments In this 
area. 

- John. 


The Personal Touch 


I am a fan of both Wayne Green 
and John Craig and would like to 
contribute toward your success with 
Kilobaud. Thus ptease allow me to 
take advantage of the $25 for a 3 year 
subscription to Kilobaud as stated by 
John in the October issue of Doctor 
Dobb's Journal and referred to by you 
in your December 73 editorial. My 
check is included herewith. 

I like the personal touch you pro¬ 
vide in your editorials — telling it like 
you see it — and hope you continue 
this policy in Kilobaud. I’ve found the 
computer articles in 73 consistently 


understandable without too much 
effort; this is more than I can say for 
Byte. 

I’m not a ham and subscribe to 73 
solely for the I/O articles but can’t 
help occasionally reading a ham article 
and am finding myself attracted to 
that branch of electronics hobbying 
due to the appeal of your excellent 
magazine. 

Please be sure that I get the first 
issue of Kilobaud! 

Terif C Young 
Shepherdstown WV 25443 


Definitely plan to keep Kilobaud both 
personaI and understandable. 

- John. 
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INCANDESCENT LIGHT DELAY. 

Small module designed to fit directly behind your wall 
swilch-plata. Turn twitch oIf and "UTE-OFF* 
light Oi half poww for 15 i* tends Wore ruining off, 
allowing you to g*l from where y&U ar* ta where you 
ain't with oat brooking a leg* Up T* 500VV!! 

Ulf-OFF Model 100 «/Instruct ions..52,15 


MT DC FT PUSH BUTTON SWITCH f CHEAP) 

Flat ihoped pi ait I c body push button D95T-NO mome«t(*y 
iwltch, 1/4" kinking mount* Body only 1/4 H X|/2 W X 
3/4 long. CPft-OMTP*.3/S*,00, 10/53.00 


SOLID STATE RELAY. 

Teledyne P/N 601-lOlOQQ ll a heavy duty solid state 
relay module operating up 10 10A at up to 250VDC * 

All brand new module*! I Slid In wigW factory packoge, 

I010QG.,,....*.*.*.*W-88 


MC144U BIT RuAT£ GENERATOR. 

Single chic for generating seladoble frequencies for equip¬ 
ment In data cocnrmwHcati on* such at TTY* printer*, CRT t 
Of microprocessors* G+fletOl** (4 different Hondcrd bit 
rates which are multiplied under external control to IX, 
8X, 16X at MX initial value* Operate* Wn tingle rS 


vail tupply. MCT44M*,**..*■*.., . 511.98 

4 page) af data....... ■ 4D 

Crystal for the above*.,**,.,♦*.,..* 54,95 


HIGH POWER TUI AC. 

Stud mount trloc mode by ECC- 200V, 25A. Port * 
O2025D it perfect for lighting, motor control, heater 
control, i&lid itota relays, etc. G7Q25D*.,.*__ 52.50 


MINIATURE SCR* MCftl 06-4 It o 2Q0V, 4 a SCR in the 
titty flat power pock* Only *2?'" wide X .13" thick '77- 
02 com). Buy this one at OEM quantity prices! HE 
MCRI06-4...* ,25c* IQ/U.0Q 


5 DECADE COUNTER 

MCI45349CP is c 5 decade real time count*r with mulliplexed 
SCO Output*. Can be cascaded lot longer counts. Typically 
iMHZ 1 operaiion at 15 Valtt* 

CMOS structure 1 for low power cant unfit ion. 

MCM534BCP**.....ill-M 


REMOTE CONTROL TRANSMITTER* MC14422P it a 22 
channel ultra-sonic remote control transmitter l*C* CMOS 
met little power and only a lew external passive compon¬ 
ent. Applications Include TV receivers, iecurity contrail, 
toy*, industrial controls and lock*. 16 pin DIP plastic pkg* I 
MC14422P....with specs..Sll.10 


PRECISION REFERENCE AMP 

LHQQ7CMH provides a precis* 30*0 vglh, far me in BCD A 
ta D converter) or mater calibrators. Typical initial accuracy 
1) .3% f- *03VI * Cartes Tn TO-5 con. 

LH007Q-1H... * *.,,. *with specs.*.. 55.35 


10 AMP VOLTAGE REGULATOR 

MPCI0O0 ii o 10 Artp positive voltage regulator od|Uslobl* 
Irons 2 TO 35 VDC. 0*1% line and load regulation wills 
0,005% per C Temperature stability * Can be fold-back 
llmlied. Here Is high current, high power with minimum 


bother* 

MPC-10Q0... *.*..♦.*.******... *116.65 

Specs far above. ......60c 


4 DIGIT COUNTER. MM74C926 ii a 4 digit causer with 
7 legmen! out pul. Cany output V COI coding and internal 
display select allows outputting af counter or scf of 
internal latches. 3 ta 6V operation. Greet for clock), 
event and frequency counter*» 

MM740926 - with spec thee!. .Sf 2*00 


NF-v NATIONAL BCOK—LINEAR APPLICATIONS VOL II 
fakes up who re Vol I left you** All tine lateit linear device*. 
Along with Vol l you have a great source af application 
data on the most widely sited devices as well as new type? 
jut! appearing *,,,*.1 * ,,i ,**..*■*,..***■■* S3 * 25 


3 DECADE (BCD) COUNTER CHIP 
MCI45 538CP consist* of 3 negative edge triggered 
synchronous counior*, 3 quod lotah** and self teon 
multiplexed , TTL Compatible outputs. 


MCI 45530 CP.,,,,,*.*58.72 

speC sheets,*,.*.,,,,.,*.*,*,*,,***.*,5*60 


INTRODUCTION TO MICRO COMPUTERS 
New book from OSBORNE, 

The first edition of this classic wot 0 huge IvCOOU. Now* 
dj* ta the growth of information on the subject Osborne has 
expanded the work into 2 volumes* Vol 1 Covets basic 
concept), Val II dlicuises real world micro computer*. 


imC- 002 Vol 1 .......50,00 

iMC-002Vaf II**.*****,..,,,***.**.,,. ,,.*.50.00 


TELETYPE CODE CONVERSION CHIP 

MMS22O0L convert) 5 level Baudot Into B level ASCII. Us* 

thi* chip to make your old TTY talk to yOur Mow computer. 


MM522O0L* **,,.,.,**,,,.*****.*. * * SI 0*00 

Spec* far the above,...,.,.*... *30 


■MOTHER NEW BOOK FROM OSBORNE. 

"8080 PROGRAMMING FOR LOGIC DESIGN' 1 explain) 

how an osiembly language program within a microcomputer 
system Con replace combinatorial logic —- for logic de¬ 
signers, programmer* ot anyone who li interested in real end 
powerful applicatrOfli O f the ubiquitous 8080* 

RLD-4QQI ..,,..* * 58*00 


DATA BOOKS BY NATIONAL SEMICONDUCTOR 
DIGITAL . Coven TTL, DTl, ftf-Stat*, etc, ***,. S3.95 
LINFAH, Covers amplifier*, pre-ampt, op-amp* f *. 53.95 
LINEAR APPLICATIONS. Dozen) of application ffca+ei and 
technical briefs covering the use of op-ompj, regulator*, 
phase locked loops ond audio amp),,, *, y 0 | l ... *, 53, 25 
CMO^ Gates, Flip Flop), register), functional block* 53 
YOU A Cf F R^GULATQRS ■ A mult for anyone meking o 
pewor supply. Complete theory Including tram Fortners, 
filters, heat sink*, regulators, etc,*...,***..,..... 53,00 
MEvQfty. Information on MQS and Bipolar memories 
RAMS, ROMS, PROMS and dHnddn/encodW*, * *.. 13.95 
fNT{RFACE. Coven peripheral driver), level translproit, 
fine driverAeceiveri, mema*y ond clock driven, seme ompi 
display driver ond optp-couplen ..*,.,.,***,.,.*... 53.95 
fOunldn U.S.* add pottage f&f 1,51bs1 

SPECIAL FUNCTIONS DATA IO O K contain* detailed 
information iar ipetrfyltV} and'applying special amplifier*, 
buffer), clock driven, analog switches and D/A-A/D 

j Converter products. .. *... *. S3.25 

AUDIO HANDBOOK canto in* detailed discussion*. 
Including "confilete design particular*, covering many 
oreo) of audio with real world design example*... 53.25 


Only 1" X 1.5". Input 5 to 15 VDC, output i* 60HZ 
square wave for portable O-r mobile dock 1 . PC bpord I* 
drilled! MTBK-6QH7. ...*55*88 


HORIZONTAL OUTPUT TF^NSISTOR, 

G.E, D56W1 ii a silicon NPN high voltage power transistor 
designed for color and b lock/whi r* TV horilantal de flee* I on 
circuit*. 

ICEV J 14O0V ** ,5mA 11 
VCF fSUS> = 600V minimum. 

TO-3 POWER PACKAGE 

05AW1 --Save on thi* one!' —--52,55 

5peo for above,—... *40 
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tRi-tek, inc. 

6522 noottl I3G£ AVCTlUG. 
Glen6*\Le. AQIZDT1A &5301 
phone 609 - 


We pay shipping on all order* over $N> US, 515 foreign in US funds* Orders 
under SlO, please add (I handling. Please add imurance. Master Charge 
and Rank America curd) welcome, {520 minimumi Telephone Order* may be 
placed MAM to 5PM dally, Mjn thru Fri, Coil 602-931-4520. Check reader 

service Card or lend Slump for our lotesl flyer* pocked with new ond lurplu) 
eledranlc components. 
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PROJECT OFF TO A SHAKY START? 
GET OFF ON THE RIGHT FOOT 
HEAD FOR THE PROS AT TRt-TEK 


Cryito! for ihe above.54,95 


TOUCH TONE GENERATOR BY 
MOSTEK* MK5086N produce* the 
dual-ton* mu!11 —frequency telephone 
dig ting *1gnqlj q* med in IT phqne* 
and au>a patches. Usei inexpensi ve { 
cry) la I, | reiHtor and 1 capacitor. 

Bath ton*) or* Internally mixed and 
buffered to o single ouiput -simple! 
Two additional OUlpvt switches con 
control timers, Irammhfer, mute re*' 
ceiv#r, enable audio amp, etc* Use* 
au* Charter its Iteyboard. Com** In 16 pin plastic DIF* 

MK50S6N.*S8.95.,.Crystal for MK5086N,,*** 51*90 

Specs far MK5066N 80«. 

Kit of pert* including etched and drilled P.C* board and an* I 
of our Chomeric* keyboardi *,*,.,**..**,,.*,,.***519.95 I 


MCI441 ? UNIVERSAL MODEM CHIP 
MC N41 2 COnlains □ complete FSK modulalof and de-mod- 
ulotor Compatible with foreign and USA comm uni cat ions, 

(0-600 BPS1 

FEATURES; 

■ On chip cryslgl oscillator 

.Echo tuppressor disable tan* generator 

.Originate and answer made) 

.Simplex, half-duplex, and full duplex apcrcfion 
.On chip sine wav* 

.Modem self lest mud* 

, Selectable data rules; 0-200 
0-300 
0-600 

.Single Supply 

VDO-4,75 to 15VDC - Fl tufflx 
VODM.75 to 6 VDC - VI )uffi* 

TYRlCAL APPLICATIONS: 

.Stand done - law speed modems 
* Bui It - in law speed modems 
.Remote terminals, act antic Coupler) 


MC144I2FL.....SI8.99 

MC144I2VI....521,74 

6 page* of data,,*.,*,,,*.,,***,,***,,* ,60 


0 AMP DARLINGTON 

MJID0Q if a Silicon NPN darlingtpn in fO-3 cose incMing 
a damping diode aUna emitter end Cal lector. 

VCEO 60V, 1C max = 8 AMP 

MJ1000* ..99(, Sped for Mjl 000..... * ,20c 


MM55TD6 PLL FReOUENCY SYNTHESISER 
18 pin DIP package JC contain* phase locked loop circulli 
useful for frequency synlhesiier application, especially those 
in or near the CB bond* Single supply operation; CMOS 
technology, binary channel 1 elect; programmable divider. 
MMS5I06N..,,...59,00. Specs..40c 


MOTOR SPEED CONTROL SYSTEM* 

UA7391 rnunalilhlc l,c, pravldei all functional blocks 
required fpr precliTan closed loop motor speed Control* 
Use for 1% can!rot accuracy on tape deck). Industrial 
eonirali, ele,,54*95,,, ...Specs .60 
























































Ft. A. Walker 
T.H. Lincoln 
AH McDonough 
6441 Hughes Dr: 

Huntington Beach CA 92647 


Front panel of Logic Analyzer Box (LA 8), model LAB-8. 


Nobody Knows 

the Troubles I’ve Seen 


T his article describes a 
compact low-cost tool 
for use in the analysis of logic 
circuits. The device connects 
to as many as 16 logic lines. 
An internal or external trigger 
is applied, and if a signal is 
present on any of the logic 
lines when the trigger occurs 
one (or more) electronic latch 
is set and a corre¬ 
sponding LED is illuminated. 

The spread of digital 
technology has been so great 
in recent years that the 
manufacturers of test instru¬ 
mentation have, at last, taken 
notice. Both of the premiere 
manufacturers of electronic 
testing devices have, in the 
last year, introduced test 
devices aimed at the digital 
computer/logic field. Even 
more encouraging, these 
devices have shown some 
recognition of the needs and 
problems of the poor soui 
faced with a maze of high¬ 
speed, nonrecurring pulses. 
The "logic analyzer" has 
proven to be an invaluable 


The authors of this article are a good example of how some of the professional digital designers 
are going to make some significant contributions to our hobby. They are , incidentally, in the 
same boat we're all in; that is; having to make sure each buck counts when it comes time to buy 
something to sustain their bobby (home computers). Therefore , you'll notice they have a 
reasonable price for those of you interested in their assembled unit. We're going to be hearing 
more from the guys at "L" Electronics , . , as a matter of fact , they have a couple of 
expansion/enhancement goodies for the LAB coming up in a future article (they uses $7,000 
HP Logic Analyzer at work . . . maybe they're going to try building something like that for the 
hobbyist). — John. 


*sy * 



Fig. 1. LAB-8 logic circuit diagram (8-bit version). 
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Prototype circuit board assembly for Logic Analyzer mode! LAB-8, 


tool in the development and 
debugging of digital systems 
but, at prices ranging around 
$7000, far beyond the reach 
of ail but the richest com¬ 
puter hobbyists, 

Most hobbyists try to 
"make-do" with an oscillo¬ 
scope. However, it doesn't 
take long to discover that 
some tests are difficult, if not 
impossible, to perform even 
with a very good scope. There 
are many instances when even 
a small logic analyzer is better 
than the best of scopes and a 
good deal easier to use and 
interpret. 

For the hobbyist, or the 
professional, the compact and 
inexpensive logic analyzer 
shown in Photo 1, can be a 
valuable tool. The logic ana¬ 
lyzer is connected to up to 16 
digital lines and to the line 
supplying the trigger pulse. 
When a trigger pulse occurs, 
the analyzer captures the 
state of the lines at that 
instant and, if the line was 
"true," iliuminates a corres¬ 
ponding LED, This display is 
retained until a new trigger 
pulse occurs or until the 
RESET button is depressed 
A manual trigger switch 
allows the user to read out 
the static state of the lines 
under examination at any 
time. 


Theory of Operation 

The logic analyzer cir¬ 
cuitry (shown in Fig. 1) is 
relatively simple and yet 
allows considerable flexibility 
of operation* The RESET 
switch (SWC) returns all the 
latches in J3 and 14 to the 
OFF state, extinguishing all 
the LED's. The TRIGGER 
select switch (SWA) is nor¬ 
mally open in the center posi¬ 
tion. It toggles to select exter¬ 
nal triggering (EXT) and 
makes momentary contact in 
the internal trigger position 
(INT). After pressing RESET, 
if SWA is pressed to I NT, the 
pulse generated by the 
momentary contact passes 
through OR gate 12 and 
causes the latches in 13 and 14 
to capture the current state 
of the input lines. 

If switch SWA is set to 
EXT, the gating is arranged to 
let external trigger pulses 
enable the latches. THE 
TRIGGER POLARITY 
switch (SWB) connects the 
exclusive OR (11) as either an 
inverting or noninverting 
buffer, allowing external trig¬ 
gering with either positive- or 
negative-going pulses. The 
trigger pulse, whether exter¬ 
nally or manually generated, 
is applied to the clock inputs 
of the SN741 75s (13 and 14). 
This latches the data present 


during the positive edge of 
the trigger pulse. 

The new data is loaded 
over any existing data each 
time the unit is triggered so it 
is not necessary to reset 


between tests. However, use 
of the manual reset between 
tests eliminates possible 
ambiguity. As an example, if 
a test indicates some error in 
a circuit you may wish to 
replace an 1C chip and repeat 
the test, tf the data display 
does not change, it could 
either be that the replace¬ 
ment did not affect the data 
or that the replacement has 
somehow disabled the trigger 
pulse and new data was never 
loaded. Use of the manual 
reset between tests eliminates 
this uncertainty. 

Construction 

Layout of the components 
is not critical. The prototype 
unit, shown in Photo 1 was 
wire-wrapped and built into a 
small plastic box with a metal 
front panel. The circuit 
assembly is shown in Photo 2. 
A printed circuit board was 
developed for easier assembly 
of subsequent units. 

Increasing the value of the 
220 Ohm resistors will reduce 
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the current to the LEDs and 
extend their lives. The use of 
alligator clips is suggested for 
power and ground to permit 
stealing power from the cir¬ 
cuit under test 

Either kits or assembled 
and tested units are now 
available with the printed 
circuit board. 

Applications 

The use of the logic ana¬ 
lyzer can be illustrated by 
considering some fictitious 
troubleshooting operations 
on a currently popular piece 
of equipment, the Altair 
8800. The intent of these 
examples is not to provide 
detailed troubleshooting 
procedures, but only to illus¬ 
trate the usefulness of the 
logic analyzer. 

First, we assume there is 
some trouble in the front 
panel control circuitry. This 
trouble has shown itself to be 
a failure of the EXAMINE 
operation. The EXAMINE 
function allows manual selec¬ 
tion of a memory address by 
front panel switches and 
display of the contents of 
that address. The relevant 
circuit is shown in Fig. 2. The 


address to be displayed is set 
on switches SAO through 
SA15. When the EXAMINE 
switch is depressed, three 
operations take place auto¬ 
matically at very high speed. 

First, octal 303 is placed 
on lines DO through D7, 
regardless of switch settings. 
Next, the low order byte of 
the address to be examined is 
placed on the same line, and 
last, the high order byte is 
pulsed on those lines. In 
summary, the lines DO 
through D7 carry three differ¬ 
ent bytes, occurring sequen¬ 
tially and automatically when 
executing a single EXAMINE 
operation. 

The standard test equip¬ 
ment available in most home 
labs is of little help in study¬ 
ing such a function. A volt¬ 
meter is of no help and a 
scope is little better unless 
you are fortunate enough to 
have a memory scope avail¬ 
able. Even with a memory 
scope you can look at only 
one or two lines at a time. 
The logic analyzer, however, 
can supply you with a lot of 
information at one time. 

Connect the logic analyzer 
inputs to lines DO through D7 


of the 8800. Connect the 
trigger input to ICW pin 10 
(Point "A" in Fig. 2), of the 
8800. This point will go high 
at load time in order to drive 
lines D2, D3, D4 and D5 to 
ground. Set the analyzer 
TRIGGER POLARITY 
switch (SWB) to f, which 
means you expect a positive 
going transition at trigger 
tima Press RESET to clear 
any old data stored in the 
latches. Set the TRIGGER 
select switch (SWA) to EXT 
and press the EXAMINE 
switch on the 8800. The logic 
analyzer should now contain 
the octal number 303. 

If octal 303 is not dis¬ 
played, you have determined 
the area in which to start 
looking for your first prob¬ 
lem. A completely blank 
display (octal 000) may indi¬ 
cate a failure to trigger. A 
logic probe, such as the 
beeper described on page 106 
of the August '76 issue of 73 
Magazine, will spot this prob¬ 
lem. 

Assuming you did get an 
octal 303 on that first test, 
the next step is to move the 
trigger input to ICU pin 8 
(Point "B"). All switches 


should remain unchanged 
except to press RESET and 
clear the display. The logic 
inputs should remain con¬ 
nected to DO through D7. 

Press the 8800 EXAMINE 
switch again and note the 
logic analyzer display. It 
should indicate the low byte 
address. Using ICU pin 11 
(Point "C") for the trigger 
point will allow examination 
of the high order address sent 
to the CPU. 

For a second example, 
consider a different part of 
the 8800, the static memory 
board circuitry shown in Fig. 

3. We assume that you have 
tried to write a word into 
memory and find you are 
unable to read that word 
back. It is not immediately 
possible to tell if the problem 
is in writing to, or reading 
from, memory. 

Start by connecting the 
data lines from the logic ana¬ 
lyzer to ICH pins 10, 2, 6, 4 
(Point ''A*') and ICJ pins 6, 

4, 2 and 10 (Point "B"), 
corresponding to DIO through 
DI7 respectively. Trigger 
from ICG pin 11 (Point "C"). 
If you have the word previ¬ 
ously stored, move the logic 
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analyzer inputs to the data 
lines 010 through DI7 and 
test again. If you no longer 
have the data word, you have 
probably isolated the prob¬ 
lem to ICH or ICJ. 

As you can see the prob¬ 
lem reduces to one of deter¬ 
mining where you want to 
look and when you want to 
sample. Sample time deter¬ 
mines the trigger points. 

Summary 

Both of the previous 
examples illustrate the testing 
of parallel data lines. This is 
by no means the only possi¬ 
ble application. It may be 
necessary to examine a single 
logic line at several points. 
The logic analyzer inputs can 
be connected to the inputs 
and outputs of several logic 
elements, either inverting or 
noninverting, to determine if 
a given signal has been 
successfully transmitted by 
each of the elements. 

This should give some 
indication of the usefulness 
of this tool. A logic analyzer 


will not replace your scope 
but it will do very well some 
jobs that a scope will not do 
at alt. 

The logic analyzer can be 
expanded from eight to 
sixteen or more bits simply 
by adding SN74175s and 
the necessary LEDs. In some 
applications it may be desir¬ 
able to trigger on a code 
word. This can be easily 
accomplished by adding a 
qualifier gate on the EXT 
TRIGGER input. 

A kit is available for either 
the 8- or 16-bit models. The 
kit includes the plastic and 
metal box shown in Photo 1, 
a silk screened panel, a 
printed circuit board, and all 
required components. The 
8-bit model is designated 
LAB-8, the 16-bit model 
LAB-16. The price of the 
LAB-8 is $55 and the price of 
the LAB-16 is $65. Both 
prices include postage within 
the United States. Order from 
"L" Electronics, 410 Bell 
Avenue, Santa Ana CA 
92707. ■ 


IMSdl 

1-8080 - Tabletop version of 
basic computer system. $539.00 

EXP-22 - Twenty-two slot 
mother board, when ordered 
with basic system.46.80 

Illinois residents please add sales 
tax. We will ship UPS prepaid. 
We honor BankAmericard and 
Master Charge. Send us $1.00 
for catalog&$1.00 credit memo. 

Quality Security Systems Computer Sales 
3407 Chambord Lane 
Hazelcrest IL 60429 


MICROCOMPUTER 

PROGRAMMING COURSE 

FREE description and outline of MODU-LEARN™ Home 
Study Course in Microcomputer Programming. Hundreds of 
pages of text with examples, problems and solutions. Pre¬ 
pared by professional design engineers using systematic 
software design techniques, structured program design, and 
practical examples from real microcomputer applications. 
Presented in a modular sequence of ten lessons oriented for 
the engineer, technician or hobbyist beginning to need pro¬ 
gramming skills. Includes background material on micro¬ 
computer architecture, hardware/software tradeoffs, and 
useful reference tables. Much of this information has been 
available only through costly seminars. Now you can study 
this complete course at home at your own pace for only 
$49.95. Send for FREE descriptive brochure now. 

| I 711 Stierlin Rd 

kiUUIL#A^k Mountain View, CA 94043 
SERVICES I NCOR PORATED (415) 965-8365 



IN NEW ENGLAND THERE ARE TWO 

Computer 

Mart 

Stores 
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TDL • SW Tech 
Sphere • IMSAI 
Digital Group 


1097 Lexington Street Route 3 
Waltham MA Merrimack NH 

617-899-4540 603-424-2981 
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White Plains Mall 
200 Hamilton Ave, 

White Plains, NY 10601 
Phone: 914* WHY* DATA 

Right off Bronx River Parkway. 
Plenty of parking. 

"STAY ON THE BUS" 
with the largest collec¬ 
tion of boards compatible with 
the Altair Bus (also IMSAI) in 
the greater NY area. 

You've read about the 
Sol-20 r now come up and 
see it. We carry Polymorphlcs, 
IMSAI, cassettes, etc., etc. 

Ask us about beginners classes 
and information on clubs. We 
provide service. 
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Microcomputers 

Digital Group 

Floppy Disks 

IMSAI 

Printers 

Natl Mux. 

Terminals 

Oliver 

Digital Tape Recorders POLY 

Special Interfaces 

Seals 

TV Monitors 

SwTPC 

Software 

SPHERE 

TDL 
& others 

Expert Help & Advice 

(Kansas City Area) 

(Washington, D.C.) 

6903 Blair Rd. 

5709 Frederick Ave. 

Kansas City MO 64152 

Rockville MD 20852 

tel. 816/741-5055 

tel. 301/468-0455 
















Dr. John Komeny 


T he Beginner's AH- 
purpose Symbolic 
instruction Code, more 
commonly referred to as 
BASIC, was developed in 
1965 at Dartmouth College in 
New Hampshire. The develop* 
ment was supported by a 
grant from the National 
Science Foundation and was 
directed by Professors John 
G. Kemeny and Thomas E. 
Kurtz. They recognized the 
need for an easy-to-use com* 
puter language which would 
make it possible for the 
layman to gain the benefits 
from a computer immedh 
a teiy , without having to 
spend endless hours learning a 
language before being able to 
apply it Needless to say, this 
accurately describes the 
results of their efforts and 
explains why BASIC is the 
language in widespread use 
within the hobby community 
today. 

Dr, Kemeny, who is now 
president of Dartmouth, had 
no contact with the hobbyist 
movement prior to being 
approached by Kilobaud for 
this interview. He has some 
interesting thoughts to share 
with us regarding the develop* 
ment of the language, some 
of the criticisms which have 


John Craig 
Editor 


Structured BASIC 

... A Negative View 
by Dr. Kemeny, 
the Author of BASIC 


been leveled at it lately, and 
where it is going in the 
future. 

Kilobaud: Was BASIC 
developed as a result of a bet 
between you and Professor 
Kurtz? 

Kemeny: If there was a 
bet, it was only whether a 
language developed at a 
school could ever compete 
with FORTRAN. I bet that it 
could, and Tom Kurtz had 
serious reservations on it. 
Nevertheless, we developed 
the language together. We 
both felt it would be worth 
while to develop a new Ian* 
guage. 

Let me set the scene. At 
that time FORTRAN was the 
only commonly used user* 
language. Several years after 
FORTRAN was developed, 
we felt that a more easily 
used language was desired, 
one of the considerations 
being that time-sharing has 
somewhat different require¬ 
ments than did batch* 
processing systems. 

Kilobaud: Did you ever 
think it would catch on the 
way it has and enjoy such 
popularity? 

Kemeny: No, neither one 
of us ever dreamed it would 
become as popular as it has. 


Kiloi)aud: You mentioned 
FORTRAN a moment ago 
, ,. would you discuss for a 
moment the relationship 
between FORTRAN and 
your BASIC? 

Kemeny: We actually 
started developing the Ian* 
guage by looking at 
FORTRAN and seeing what 
we liked in it and what we 
disliked in it. And of course, 
later on, FORTRAN 
incorporated some of the 
things we had put into 
BASIC, So, I think in many 
ways the difference between 
FORTRAN and BASIC is less 
than it originally was and 
each language has profited 
from the other language. I'll 
tell you what my two major 
concerns were when I devel¬ 
oped BASIC. In the original 
FORTRAN, you had to learn 
an enormous amount before 
you even got started. You 
had to learn an awful lot of 
things before you wrote your 
first program. I thought this 
was not good for a beginning 
user. Therefore, we wrote 
BASIC in what we call 
"levels." We could get up to a 
given level, live there quite 
comfortably . ,, and then 
move onto the next level. 

The second concern was 


that the time-sharing would 
be in a conversational mode. 
We felt that would enable us 
to simplify things for the user 
more than was possible at 
that time using FORTRAN. 
We were after such features as 
having line numbers and 
automatic editing of a line by 
retyping. These features have 
since been incorporated into 
other time sharing languages, 
but BASIC was the first to 
have them. Of course, it was 
the first to have an INPUT 
statement, because it only 
made sense in time sharing 
for the user to supply data. 

Kilobaud: Would 1 be 
correct in assuming that 
you're aware of growth of the 
hobby movement and the use 
of BASIC in home computer 
systems the last couple of 
years? 

Kemeny: Yes, I 've heard a 
good deal about the hobby 
movement. 

Kilobaud: As far as home 
systems are concerned, do 
you see any possibility of 
BASIC being replaced in the 
future with another language? 

Kemeny: I don't see any 
need for that Obviously, if 
somebody comes up with a 
better language it should be 
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used But, what might be 
(deal for the hobby systems 
would be our original effort 
called, Baby BASIC, There is 
an enormous amount that can 
be done with minimal BASIC, 
and it can be implemented on 
a very small computer. 

Kilobaud: Have you had 
any inputs, or a voice, with 
regard to the standardization 
efforts currently underway 
for BASIC? 

Kemeny: Not personally, 
but Professor Kurtz and 
another Dartmouth professor 
Steven Garland have played a 
leading role (particularly 
Professor Garland) in the 
standardization of BASIC . . . 
and we're very happy with 
the way it is coming out. 

Kilobaud: As far as you 
know, has the standardization 
committee received all of the 
inputs by now? 

Kemeny: Yes, they have 
even made contact with an 
overseas group working on it 
and l think all the major 
problems have been resolved. 


Kilobaud: From what I've 
heard there is not a BASIC in 
existence which meets the 
m in i m um p r op osed st a tv 
(lards, because of the need for 
an OPTION state command 
(which allows the operator to 
specify whether an array 
starts at zero or one). There is 
no OPTION command in any 
BASIC around. 

Kemeny: That may be. I 
wasn't aware of that fact. 1 
did ask and l know we're 
going to have to make some 
minor changes in our BASIC 
to live up to the standard . ., 
but I was told they were 
quite minor. 

Kilobaud: Recently there 
have been some articles in 
several publications which 
have been critical of BASIC 
with regard to the fact it 
doesn't lend itself to struc¬ 
tured programming. What are 
your feelings on this matter? 

Kemeny: Let me express a 
personal prejudice, which, 
incidentally, many of my 
colleagues don't agree with. 1 


think some of the arguments 
for structured programming 
have been badly exaggerated. 
It reminds me of a branch of 
mathematics which becomes 
very well developed and the 
purists take over and impose 
upon that branch conditions 
of high purity. I'm not a great 
believer in that . * , I feel that 
for the majority of pro¬ 
grammers such things as 
structured programming just 
get in the way. I think a 
relatively few safeguards, like 
those in ordinary program¬ 
ming, can achieve 95% of 
what structured programming 
can. 

Kilobaud: At this parties 
lar point in time it really 
seems a waste to be sitting 
around discussing BASIC's 
shortcoming. What we really 
need, especially in the hobby 
community, is to get busy 
and develop some good appli¬ 
cations software. That's 
where we're lacking right 
now. 

Kemeny: Yes, l quite 
agree with that. BASIC has 


lent itself to tens of thou¬ 
sands of users writing endless 
numbers of very good appli¬ 
cations programs and none of 
them seem to be handicapped 
by any particular feature of 
BASIC. 

Kilobaud: Fine ... I 
would have expected a 
response such as that from 
you, but it was nice hearing it 
anyway. 

Well, Dr. Kemeny, I guess 
that should just about do it. 
Have you anything to pass 
along in summary? 

Kemeny: Yes, let me 
express one basic prejudice 
which is relevant to our dis¬ 
cussion on structured pro¬ 
gramming. I think that it is 
terribly important that the 
computer experts, and 
though I consider myself one 
of them, \ still have a 
prejudice that computer 
experts should not be allowed 
to interfere too much with 
the pleasure of the lay com¬ 
puter user and put in too 
many limitations as to what 
the lay user can do. m 



NEW! From Solid State Music 

64 x 16 VIDEO BOARD (At last) Altair plug compatible display 32 x l6or64x 16 
switch selectable. Composite and parallel video ports, 8-9TL02A memory 
for graphics and text, upper and lower case 2x3 grid for each location on 
graphics, with software. Kit.SI79.95 
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Glossary 

This glossary was researched and compiled by Doug Hogg of 
Santa Barbara CA with assistance from John Goettelmann of 
PL Pleasant NJ. To try to make it as useful as possible we've 
read each article with an eye to terms which we felt might be 
confusing to the beginner . If you feel we've missed a term that 
should have been defined\ please drop me a note asap, and 
we'll try to get it to press for the next issue . — John. 


ALGORITHM: A rule, method, or procedure used for solving 
particular problem or class of problems. 

Normally, in programming, the word is used to describe a 
simple, yet powerful, rule which may be applied to solve a 
commonly encountered problem, one of the two basic 
ingredients of any program (the other being data). The 
algorithm specifies the rules by which the data is to be 
processed in order to meet the objective of the program. 

Example: 


Problem Statement 

Add the numbers in 
Boxes A and B together 
and write the result 
in Box A, 

A 500 
B 100 


Algorithm 

1. Take the con¬ 
tents of Box A 
and add it to 
the contents of 
Box B. 

2. Place the sum in 
Box A. 


Result 
A 600 
B 100* 


*Box B is unchanged since no instructions were given to change it. 


AND GATE: A circuit element whose output will be a logical 
one when, and only when, all of the inputs are in a logical one 
state. The truth table for a two input AND gate is shown 
below. 


Inputs Output 
A B 

0 0 0 

1 0 0 

0 1 0 

1 1 1 

The symbol for the AND gate is: 


Output 

Also see logic. 



ARCHITECTURE: A loosely defined term which refers to the 
interrelationships between the principal parts of a computer 
system and the methods and paths by which data can be made 
to flow within the system. 

Aspects of a computer system which are usually investi¬ 
gated when considering the architecture of one system over 
another are: 

The number of registers available and how they can be 
utilized 

The number of stacks available and how they can be 
utilized 

The instruction set with regard to the control of input/ 
output operations 

The hardware interrupt structure 

The number and kinds of data paths into memory 

The number and kinds of data paths into the CPU 

Architectures are generally classified into one of two major 
categories: 

Central processor oriented 
Memory oriented 

Each category has its own set of advantages and disadvan¬ 
tages, depending on the intended use of the system and 
permissible costs. The memory-oriented architecture is by far 
the most flexible, since it permits both the CPU and the 
various input/output devices to access memory freely and 
independently, if desired. The CPU-oriented architecture is 
frequently less expensive, but suffers in performance because 
the CPU has to move, or at least control, all of the data 
moving into and out of memory. 

ARGUMENT: In programming, it is frequently desirable to 
design a subroutine to acquire a sequence of one or more data 
items from the part of the program which called it. The 
subroutine uses these data items, applying some algorithm, to 
accomplish a specific result. The data items passed from the 
calling to the called parts of a program are referred to as 
arguments . 

As one moves from simple assembly language programs to 
higher level language programs, topics relating to arguments 
and how they are actually passed between the various program 
segments become quite complex. 
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ASCII: Acronym for American Standard Code for Information 
Interchange. This is a code which assigns a seven bit binary 
number for each letter of the alphabet, numbers and punctua¬ 
tion marks. In addition, certain machine codes (carriage 
return, line feed, end of transmission, tab, etc.) are also 
assigned codes. This is the standard coding used in TV 
Typewriters, all of the hobbyist video driver systems and the 
newer TTYs (as opposed to the older, Baudot code machines). 

ASYNCHRONOUS OPERATION of a system is at a rate not 
constant in frequency and phase with respect to a master 
clock. The input of a TTY to a computer is an asynchronous 
operation since the inputs occur at random times determined 
by the system operator, not the computer clock. 


6 110 

7 111 

Also see BCD, octal, hexadecimal. 

BIPOLAR refers to the use of conventional transistors (NPN 
or PNP) as opposed the field effect transistors (FETs). The 
distinction arises since the bipolar transistor is constructed 
from semiconductor material with sections of both N-type and 
P-type doping while each MOS FET is made of material with 
only one type of doping. 

BIT is one b/nary digit. For instance, the binary number 
11001 has 4 bits. 


BAUD: A data transmission rate of one bit per second. For 
example, the standard TTY speed is 110 baud, or 110 bits per 
second. 

BAUDOT: A code, similar in concept to ASCII, assigning 
numbers to letters of the alphabet, numbers and punctuation 
marks. This code uses only 5 binary bits (32 possible 
combinations) and so does not have a unique code assignment 
for each character. There are two codes for case shifting 
(letters and figures) which allow a total of 60 different 
characters to be represented in this code. Thus to send "a158" 
the following characters would be sent: letters, A, figures, 1, 5, 
letters, B. 

See also ASCII. 

BCD: Binary Coded Decimal. A method of representing 
decimal digits in the form of 4 bit binary words as shown 
below: 


Decimal 

BCD 

Binary 

0 

0000 

0000 

1 

0001 

0001 

2 

0010 

0010 

3 

0011 

0011 

4 

0100 

0100 

5 

0101 

0101 

6 

0110 

0110 

7 

0111 

0111 

8 

1000 

1000 

9 

1001 

1001 

10 

1 0000 

1010 

11 

1 0001 

1011 

12 

1 0010 

1100 

13 

1 0011 

1101 

14 

1 0100 

1110 

15 

1 0101 

1111 


BCD may be converted to decimal by converting each group of 
4 bits to a decimal digit. Note that this does not work for 
straight binary. 

BINARY: The base two numbering system. Each digit may be 
either a 1 or a 0. In decimal (base 10) each digit to the left 
increases in value by a factor of 10. In binary each digit to the 
left increases by a factor of 2. The table shows the binary 
equivalents of decimal 0 to 7. 

Decimal 
0 
1 
2 

3 

4 

5 


Binary 

0 

1 

10 

11 

100 

101 


BUFFER (DRIVER) is a circuit used to isolate a load from the 
driving source. For instance, a buffer is usually used between a 
microprocessor chip and the memory address lines to boost 
the small drive current from the microprocessor 1C (typically 
less than 2 mA) to a higher value suitable for driving a large 
number of devices simultaneously (typically a maximum of 50 
mA). The most common types of 1C buffers are the 8T97 and 
8097 which have 6 buffers per chip, require .25 mA at the 
input and will drive up to 50 mA at standard TTL voltage 
levels. 

BUFFER STORAGE AREA: A temporary storage area for 
data. This may be a single word of storage (such as in an 
output port latch holding data until the output device has 
accepted it). A buffer area in main memory can range from a 
single location to a large block. 

BUS: A group of connections which carry information to the 
various parts of the computer. As an example, the data bus 
lines go to the CPU memory and input-output devices. A 
typical microprocessor bus system consists of parallel lines 
which carry the processor status signals, memory address, data 
and control signals to all of the circuit boards. In such a bus 
system, any card may be plugged into any position since each 
pin on each connector carries the same signal. 

BYTE: A unit of data which consists of eight binary digits. 

CMOS: Complementary MOS. This refers to a family of 
integrated circuits whose output structure consists of an 
N-type MOSFET and a P-type MOSFET in series. The term 
complementary is used since the N and P-type MOSFETs are 
complements of each other. 


Vcc 


Input 


CMOS Inverter 


4 


Output 


CPU: Abbreviation for Central Processing Unit This is the 
heart of the computer which actually carries out the instruc¬ 
tions contained in memory. The 8080, a typical small CPU, 
has several internal registers for holding temporary results and 
addresses, a stack pointer which contains information used in 
subroutine calls and returns, a program counter which contains 
the address of the next instruction to be executed and an 
arithmetic logic unit (ALU) which performs the mathematical 
and logical operations. A complete computer consists of the 
CPU, memory and input-output devices (I/O). 

Also see MPU. 
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F 

10 


DIP: Abbreviation for Dual Inline Package. This is a case type 
commonly used for integrated circuits. The package has two 
parallel rows of pins on either side of the package spaced 
.100" apart Packages presently available have either 8,14,16, 
18, 20,22,24, 28 or 40 pins. 

EROM: Eraseable Read Only Memory. This is a special type of 
read only memory which can be programmed electrically. The 
unique feature is is that it retains data even with the power 
disconnected but can be erased by exposure to short wave¬ 
length ultraviolet light {sunlight is not sufficient). The device 
may be reprogrammed many times. Common types are the 
1702A (256 8 bit words), the 5204 (512 8 bit words) and the 
8708 (1024 8 bit words). 

Also see ROM, PROM and RAM. 


15 

16 

Binary can be converted to hexadecimal by summing each 
group of four binary digits. For example: 

Binary 10110110 

Hex B 6 

Also see BCD, binary, octal. 

INTERRUPT usually refers to a hardware signal used to 
represent the occurrence of a real time event within a 
computer system. The occurrence of this event (and the 
generation of an interrupt signal) forces the computer to 
immediately stop whatever it is doing and take appropriate 
action in response to the event. 


INTCRRUPT 



Example: Suppose your home computer is being used to 
constantly monitor the environment. It’s checking the temper¬ 
ature sensors in the lawn to see if the lawn needs water, the 
time of day to adjust the solar panels on the roof. It's also 
monitoring the security and fire systems, just to name a few. 

If you desire to communicate with your computer, it’s 
going to be done on the basis of "interrupting” these other 
functions. When you hit a key on the keyboard (to request a 
particular function) an interrupt is generated. The processor 
completes the instruction it is currently executing ... and 
then begins executing an Interrupt Handling Subroutine which 
will determine which key on the keyboard was depressed and 
exactly what action needs to be taken. At the completion of 
the subroutine, control is returned to the main program (the 
one which was originally interrupted). 

INTERRUPT LINKAGE refers to the technique which causes 
the computer to switch to (and then return from) the 
"interrupt handling" portions of the program as various 
interrupts occur. 

KILOBAUD: A data transmission rate of 1000 baud (one 
thousand bits per second). 

KIM: A self contained microprocessor board produced by 
MOS Technology Inc. The one board unit has a 6502 CPU, 
2048 words of ROM, 128 words of RAM, a keyboard, LED 
display, a TTY interface and an audio cassette interface. 


EXCLUSIVE OR: The exclusive OR gate will provide a high 
output only with unlike inputs (i.e., one input high and the 
other low). The Exclusive OR is commonly used as a 
comparator and can also be used to perform simple binary 
addition. The truth table and logic symbol are shown below. 


Inputs 
A B 


0 

1 

0 

1 


0 

0 

1 

1 


Output 


0 

1 

1 

0 


Exp: Exclusive OR as comparator 




“ERROR" or 
unlike data 
during comparison 



Symbol 


30 


Binary addition: 


>>1 1 
Carry +1 


1 

+0 


o 

+1 


0 

+1 


Also see logic. 

FLAG: A single bit used to indicate the result of a test. 
Typical microprocessors have flags for such functions as zero 
test, positive test, and carry. For instance, if the contents of a 
register is zero, the zero flag will be set. If a register contains 
001, then only the positive flag will be set (the most 
significant bit is the sign - "0" = positive, "1" = negative). 
Flags are generally used as the basis for conditional jump 
decisions (Jump if Zero, etc.) 

HEXADECIMAL: A method of representing numbers using 
base 16, as shown below. 


Decimal 


Hexadecimal 


0 

1 

2 

3 

4 

5 

6 

7 

8 

9 

10 
11 
12 

13 

14 


0 

1 

2 

3 

4 

5 

6 

7 

8 
9 
A 
B 
C 
D 
E 


LOCATION refers to a position or address in memory (for 
example, making reference to the data in location 377). 

LOGIC: In electronics, certain circuits are used to perform 
logical functions. The functions are AND, NAND, OR, NOR 
and Exclusive OR. The output of these circuits is dependent 
on the state (1 or 0) of the inputs. 
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MEMORY PAGE: A section of memory, typically 256 words. 
This arises from the fact an 8 bit computer handles memory 
addresses in 8 bit bytes. One byte can address 256 locations so 
most 8 bit microprocessors use a total of 2 bytes to give one 
16 bit word capable of addressing 65,536 (2^ 6) locations. The 
upper 8 bits are referred to as the page number. Thus the 
address in octal page form 012 125 is location 125 (octal) on 
page 012 (octal). 

MEMORY PROTECT refers to the ability to selectively disable 
the write line on a memory segment. In this way the 
information in the memories can be protected from accidental 
destruction from inadvertantly writing in new information. On 
some memories this feature is set manually and on some units 
the memory protect can be set or reset under control of the 
operating program. This system does not protect against loss 
of the memory data due to interruption of the power supply. 

MNEMONICS: A technique of improving the memory. In 
programming the symbolic codes used for instructions, ad¬ 
dresses and data in assembly-language are referred to as 
mnemonics. These symbols (for instructions, in particular) are 
certainly easier for the programmer to remember than the 
octal or hexadecimal equivalent in machine-language. 

MOS: Acronym for Metal Oxide Semiconductor. This refers to 
the three layers used in forming the gate structure of a field 
effect transistor (FET). 


Gate 


Junction 
Source - 




Semiconductor 
— Drain 


Junction FET. The gate is P-type semiconductor diffused into 
the bulk material. 


Gate 



Source 


Metal 

Metal oxide layer 
Semiconductor 

Drain 


MOS FET. The metal gate is separated from the main body of 
the FET by an insulating layer of metal oxide. 

The bulk material may be either N-type or P-type. These 
are called NMOS and PMOS. Because this is a simple process, 
many of the higher density integrated circuits (particularly 
memories) use this process. These integrated circuits are 
referred to as MOS ICs. 

MPU: Abbreviation for microprocessor unit. Refers to a 
Central Processing Unit (CPU) implemented with an integrated 
circuit microprocessor. 

Also see CPU. 

NAND GATE: A circuit element whose output is the negation 
(or complement) of the logical AND function. The output is 
logic level 0 only if all the inputs are at logic level 1. The truth 
table and symbol for a 2 input NAND gate is shown below. 


NOR GATE: A circuit element whose output is the negation 
(or complement) of the logical OR function. The output is a 
logical zero if any of the inputs are at logical one. The truth 
table and symbol for a 2 input NOR gate is shown below. 


Inputs Output 

A B 

0 0 1 

1 0 0 

0 1 0 

1 1 0 

OBJECT Format or Program: See SOURCE PROGRAM. 

OCTAL: A method of representing numbers using base 8. The 
first 12 numbers and their decimal equivalents are: 

Decimal Octal 

0 0 

1 1 

2 2 

3 3 

4 4 

5 5 

6 6 

7 7 

8 10 

9 11 

10 12 

11 13 

12 14 

Binary can be converted to octal by taking groups of three 
binary digits and summing the values. For instance, 

Binary 101 010 

Octal 5 2 

Also see BCD, Binary, and Hexadecimal. 

ON-BOARD REGULATION refers to the practice of placing 
small voltage regulators on each circuit board in a system 
rather than having one large power supply for the entire 
system. Altair-compatible circuits use on-board regulation. 
Advantages include the ability to expand the system gradually, 
the isolation of electrically noisy circuits, and no noise pickup 
on the power supply wiring. The disadvantages include the 
necessity for a large number of voltage regulators and the 
placing of heat sources on the cards. 

OPERATOR/OPERAND: A statement will consist of an 
operator — the instruction and an operand — the data to be 
“operated upon.’’ In the following example, the statement 
consists of a LoaD a Register instruction (LDA) along with an 
operand address, which is 500. LDA is The contents of 
location 500 is the OPERAND. 


OR GATE: A circuit element whose output is logical if any of 
the inputs are logical. The truth table and symbol for a 2 input 
OR gate is shown below. 



Inputs 

Output 


A 

B 


B H] — Output 

0 

1 

0 

0 

0 

1 


0 

1 

1 

1 

1 

1 
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POINTER: In its most common useage, a pointer refers to an 
address which is used to identify the location in memory 
where something can be stored or found. The object “pointed 
to” could be an ASCII character, a table of some kind, a 
variable, an interrupt handling routine, or just about any kind 
of program or data structure imaginable. 


MEMORY 


INSTRUCTION 

BEING 

EXECUTED 


STAX B 


REGISTERS 


* 


3F 


16 


THE 

•POINTER” 


0 


E 

H 


L 

A 


L 3FI4 
3FI5 
3FI6 
3FI7 


REGISTERS BAG 
FORM EFFECTIVE 
ADORESS FOR 
“POINTING" TO 
LOCATION INTO 
WHICH ACCUMU¬ 
LATOR IS TO BE 
STORED. 


An example of an operation using a pointer would be the 
8080 instruction, STAX B. This instruction is used for storing 
the contents of the A Register (accumulator) into a memory 
location specified by the B and C Registers. In this case, the B 
and C Registers are being used as pointers (i.e., pointing to the 
location in memory in which A Register should be stored). 

Note that in some computer literature the word vector is 
used interchangeably with the word pointer and has the same 
general connotations as described above. 

PHOTODIODE: A special type of diode which allows a 
current flow proportional to the amount of light striking it. 
This may be thought of as a transistor with light providing the 
base current. Almost all transistors will, when removed from 
their protective cases, function as photodiodes. 


This, compared to shift register memory where all of the 
locations must be examined sequentially. There are two types 
of RAM: Static RAM and Dynamic RAM. Each memory cell in 
a static RAM is composed of a flip-flop storage element. As 
long as the power is not interrupted the memory cell will 
retain the information. In a dynamic RAM the storage cell is a 
capacitor which must be continually recharged to maintain a 
one state. This recharge process is called refreshing and is done 
by cycling through the address lines. Dynamic RAMs take less 
circuitry and therefore are more dense than static RAMs, 
although the refresh does require some external circuitry. 
Presently, dynamic RAMs of up to 16,384 bits/chip and static 
RAMs of up to 4096 bits/chip are available. 

ROM: Abbreviation for Read Only Memory. A memory device 
which has a fixed content in each location. A simple example 
is a diode encoding matrix for a keyboard. The most common 
devices are integrated circuits which have the memory 
contents set by the mask used in manufacture. Integrated 
circuit ROMs are available with up to 48,000 bits per chip. 

Also see RAM, EROM, PROM, EAROM. 

SOURCE PROGRAM: A program written in symbolic code for 
an Assembler, Interpreter, or Compiler. For example, with a 
Motorola 6800-based system an assembly-language program 
could be written using symbolic code, such as LDS to specify 
loading the stack pointer. This mnemonic (LDS), along with 
all the other symbolic code making up the program, will then 
be translated, using an assembler program, into machine 
language (or object code). In the case of the LDS instruction, 
the equivalent machine code would be hexadecimal BE. 

In the case of a BASIC interpreter or compiler the source 
code would be the BASIC statements and commands making 
up a program. Naturally, these will have to be translated into 
machine language (object code) by the interpreter or compiler 
before execution can take place. 


The SOURCE PROGRAM 
(Written in symbolic code) 



Machine 

Symbolic 

Instruction Operand 

1 

Location 

Code 

Address 

Mnemonic 

Data/Add r 

Comment Field 

1000 

C6 08 

BCD 

LDA B 

*NB 


1002 

FE 01 00 


LDX 

ADDR 

LOAD DATA ADDR 

1005 

OC 


CLC 



1006 

A6 07 

NEXT 

LDA A 

NB-l.X 



The Executable 
Machine Code 
(or, OBJECT CODE) 


PRIORITIZE: In computer systems, to prioritize means to 
arrange a group of similar things in some order based upon 
their relative importance to one another. The ordering can be 
in terms of either location or time. 

PROM: Programmable Read Only Memory. Programming is 
accomplished by burning out fusable links at each memory 
cell. This is done by flowing a large current through the 
nichrome link. The programming is permanent and is a useful 
way to store programs, but manual programming can be very 
tedious and mistakes cannot be erased. Common types are the 
8223 and 825123 (32 8 bit words). 

RAM: Random Access Memory. Also called Read/Write 
memory. These units consist of memory cells which can have 
information (either a 1 or a 0) stored in them. The individual 
cells may be accessed in any order (hence the term random. 


SWTPC: Abbreviation for Southwest Technical Products 
Corporation, a company specializing in kits for the hobbyist. 
They introduced the TVT-1 (a Television typewriter which 
displays characters from a keyboard on a standard television 
screen) in 1973, an improved version, the 7VT-II in 1974, the 
6800 computer using a Motorola 6800 MPU in 1975 and two 
versions of BASIC for the 6800 in 1976. 

SYNCHRONOUS OPERATION of a system is governed by 
(and synchronized to) a master timing source. Synchronous 
means constant frequency and phase. For example, in a 
computer the data transfers occur at definite times relative to 
the system clock. 

Also see Asynchronous operation. 

TTL: Abbreviation for Transistor Transistor Logic. This refers 
to a family of integrated circuit logic elements with a specific 
output structure. The output stage consists of a pair of 
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transistor as shown in the diagram. 



v 


CC 


Output 


Gnd 


In a zero state (output low) the upper transistor is off and 
the lower transistor is on. In the one state (output high) the 
lower transistor is off and the upper transistor is on. In this 
way the output stage has the ability to source or sink a large 
amount of current if necessary, but does not have to dissipate 
this power if not needed since only one transistor is on at a 
time. In addition the active current source of TTL allows 
higher speeds. 

Also see CMOS, Bipolar. 

TTY: An abbreviation for Teletype* (or other teletype¬ 
writers), a machine which looks much like an electric 
typewriter and is used for communicating with a computer. 
These units are often equipped with a paper tape reader and 
punch. The advantages of the unit are the hard copy output 
and the ability to read and punch paper tape. Their disadvan¬ 
tages are slow speed (10 characters per second), high cost 
(about $1500 new), high noise level and need for frequent 
maintenance. 

♦Registered trademark of the Teletype Corporation. 

UART: Acronymn for Universal Asynchronous Receiver - 
Transmitter. As the name implies, the unit has a transmitter 
and an independent receiver. The UART transmitter accepts 
parallel input data and transmits it serially. The receiver 
converts serial input data to parallel output data. The 
transmitter inserts the desired number of start bits at the 
beginning of the transmitted word and stop bits at the 
end of the word. If desired, a parity bit is inserted. The data is 
then transmitted out at a data rate (baud rate) determined by 
the transmitter data clock. The receiver section looks for a 
valid start bit at the beginning of a serial data word. When one 
is received, the receiver converts the incoming data to a 
parallel output word. The receiver only responds to data input 
at a rate determined by the receiver data clock. In addition, 
the receiver checks for parity and data overrun errors (new 
data received before the last data was read). 

The primary use for UARTs is for interfacing serial data 
devices to parallel devices. Examples are TTY to computer, 
computer to telephone line, and computer to tape recorder. 
V cc : The collector power supply voltage. In TTL this is +5 
volts. Other terms used for the various supplies are Vbb> v DD 
and V$s (B, D, and S standing for bias, drain and source 
respectively). Typical values for these are Vbb = -5, Vqd = 
+12 and V$s = 0. The current flowing from these power 
supplies is denoted by a capital I with the subscript appro¬ 
priate to the particular supply (IcG *DDi *BB)- 

VECTOR:- See “Pointer” 

WORKSPACE is a loosely defined term usually taken to mean 
the amount of memory required by a program, over and above 
the amount of memory required to store the program itself. 
Workspace is typically used for input/output device buffer 
areas and for various other locations required by a program 
during its execution. 


Morse code is about as handy for a computerist 
as a Babbage computer ... you'll probably want 
to learn this lovely old method of communica¬ 
tions. 

Since you'll undoubtedly be wanting to get in 
touch with some other computerists, and you may 
be too chintzy to pay Ma Bell her due day in and 
day out, the chances are good that you'll even¬ 
tually want to get a Ham license. You have to 
know the code for this ... a hangover from the 
20's and 30's, which is still being kept alive within 
the hallowed halls of the FCC. 

If you want to learn the code then the 73 code 
tapes are by far the easiest way known to man to 
do it. The #5 cassette (one hour) will get you 
familiar with all of the letters, numbers and 
punctuation you'll need to convince the FCC to 
let you Ham. The #6 cassette is strictly practice 
and is about as difficult as six word per minute 
Morse code can get. You'll love it. 

#5 Intro to Morse Code $4.95 

#6 Back Breaker Practice $4.95 

#13 13 WPM Code Practice $4.95 

We do have some other code tapes available... 
10 WPM for Canadian licenses,#20 WPM for the 
Amateur Extra license, and 25 WPM for maso¬ 
chists. $4.95 each. 

THEORY TAPES 

A set of four one hour tapes has been devel¬ 
oped for class use to teach the fundamentals of 
electricity and electronics, enough to get you 
through the Novice license. The whole set is 
$15.95 ... a bargain. These are great for use in the 
car, during lunch breaks, etc., if you have a small 
cassette player. 


(finp 


L MORSE CODE TAPES @ $4.95 

□ #5 □ #10 

□ #6 □ #20 Q 


□ #13 □ #25 


THEORY TAPES 
SET OF 4- $15.95 


Name_ 

Address. 
City_ 


. State- 


_Zin 


-Enclosed DCash □ Check □ Money Order 

[ □ American Express □ Master Charge □ BankAmericard 


Card#. 


Interbank #_ 
Signature_ 


Exp. date. 


kilobaud 


prrcRbonouqh Nh 09498 


1/77 
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Fig. 1. Main schematic with the optional 2 MHz clock shown. Four “C" cells work well for Vcc. 

-vce 


Soon after A! finished build * 
ing this video game he 
brought it over to my house 
and left it for two days, i had 
to practically pry it out of 
the hands of my kids when 
the time came for him to take 
it Go ahead and build one 
for the family for Christmas 
. ♦ . they'll love ya for it. - 
John ■, 


I t’s finally here *,, a one 
chip ‘'pong." And it's not 
just a single-game-wham- 
bam-gcbborcd-quick type of 
chip. This one has six 
separate and unique games. 
So when you think you have 


Six Games on a Chip 

... TV tournament time 














SOLID STATE 



7417& 1 30 
74170 1 70 
7417T 1 30 
74178 1.40 
74 U 9 t SO 
741*0 t JO 
741 HI 3 ID 

74113 1 OO 

74114 j10 
7410* 3 90 
7*1 *1 9 00 

74190 MD 

74191 t JO 

74193 1 30 
741U3 1 JO 

74194 1 JO 
74190 1 00 
74HJO 1,40 
74197 I 40 
7419* 1 40 
74100 1 40 
74300 7 00 
74331 I 40 
7433* 1 30 
74 Ml f 10 


74L 500S 
74LS01M 
74L50JN 
74L503*1 
74LS04N 

74L90SN 
, J4Y5Q8M 
74lS 09N 
74LSION 
•74LS17N 
I 741.S13N 
74LS20N 
74i.!i31N 
741 gjjn 
34 LS 37 N 
|T4L$JCK9 
' 74LS32N 
74 LS 33 N 
? 41 5377 * 
74L3JSN 
74 LS 40^1 
74|3*JM 


74300 
7*502 
74‘JLG4 
7*:>ce 
74E io 


GEORGIA 

ANCHQNA 

SSTOPiddm&nt Fld.Nl 
Alania, <jA M30S 
T4JMI 201-7100 


ikhmhou mi 

jubtm^h lM 


DISPLAYS - I COMMON ANODE I Data Sh*v1 EPlOflO l J9 
LARGE 1" XCITON 

FPIOOO MED 9.50 XAN72 RED 3.00 

3 pci EP10OO IS W XAN62 GREEN 2 00 

9n-« EPIO0Q 33 60 XAN13 YELLOW J 00 

L1THDNIX J" LITHONtX O' 

DL?Q^_n E P 2 39 DL747 RED 3 JO 


COMPLETE KIT 
— ONLY $ 40,00 


MV50 of o 4 30 

opto coupi.fiit 

MCTJ 1.60 


7400 

IB 

7432 

32 

7460 

.60 

7*128 

60 

HU 1 

20 

7433 

.44 

74£? 

1.60 

74132 

1 50 

7402 

1« 

7437 

36 

7483 

B2 

74 I 36 

1 B0 

7403 

20 

7-139 

35 

7485 

1.20 

74141 

1 70 

74U4 

25 

740y 

36 

74S0 

44 

74143 

1.20 

7403 

JJ 

7440 

20 

748fl 

3 ?0 

7*147 

2 00 

7406 

30 

7441 

.90 

I4D0 

.96 

7*14* 

1 80 

740 7 

36 

7443 


7493 

60 

74*50 

1 7D 

7400 

29 

7443 

75 

7*93 

.63 - 

741$1 

1 20 

7*00 

2& 

7444 1 

.05 

7*94 

83 

74162 

1.2.0 

74 ID 

32 

M46 1 

.05 

7*96 

93 

74153 

1 20 

741 1 

24 

744G 1 

06 

7*96 

80 

7*15* 

1 20 

7*12 

.36 

7447 

98 

7497 

6,00 

7*181 

1 ID 

7413 

94 

744H 

96 

74100 

1.20 , 

74198 

1 20 

7414 

3B 

7490 

15 

74 109 

90 

74197 

■ 20 

7416 

42 

7*91 

16 

74107 

40 

74194 

1 *0 

7417 

43 

7453 

18 

74 ICTJ- 

49 

741«0 

1 30 

7430 

15 

7494 

18 

741 10 

30 

74101 

1 *□ 

7421 

38 

1 460 

26 

74111 

1.00 

74162 

190 

7422 

60 

, 7400 

19 

74110 3 00 

741 63 

i 50 

7*33 

39 

7470 

40 

74116 

2.DO 

7*16* 

1 50 

7426 

40 

1 7*72 

40 

741JI 

00 

7*185 

1 50 

74J0 

» 

, 7473 

*2 

741 JJ 

48 

74168 

l 60 

7427 

36 

7474 

42 

74123 

.09 

7*170 J 00 

7426 

60 

7479 

70 

74126 

.59 

7417 J 

1 70 

7*30 

26 

7*70 

iA 

74136 

60 

7417a 

1 20 1 


30 74L&51N 

44 

3* 74LS95N 
*0 74L573N 

44 74L*?4N 

44 74L575N 

39 74L576N 


74 L SCO 

44 741 S1 33 N 1 44 
44 74LS139N 74 
44 74-L5I3BN1 AO 

5JS 74t,SiMNlH9 
.61 74LS1*5M94 
./l) 74LS151N1 *6 
03 74LS153N1 JU 


44 ! 74L.S 76 V 03 74».51fi7Nl ,30 
30 74LSS3AN 144 74L$l69N161 
44 Ul 5.S5-V. 3 MJ 74LS160N3 0D 
44 74LS&6AH *9 ?*LS1&1N1,50 

44 74tS50ANM4 74LS103N110 
*4 74LS93AN *9 74LSI63V1 %Q 
44 74LS93AN 16 74LS164N1 CO 
44 741 SUSAN 3 19 T4I.SI70N3J0 
36 741S96AN134 741.S174V1 30 
44 7*1$107H !l* 74LSU5N1 30 
66 74LSI09V 64 74131811*5 90 

6D 74 lS 113 V 94 74LS19DN3 16 
&U T41S1T3N 64 74L5191U3 70 
44 741.51 UN 02 74L319i3N 1 40 

.93 74L.S123N1.1U 

HIGH SPEED TU 


74LSI93N1 70 
74lS 11I*AJJ20 
74LS196AJJ20 
74LS194N2 76 
74L6I97N7 64 
74L6J21N1 ?6 
74L5241N3 00 
74LS291NJ 06 
T4LS2&3N3 40 
ML6j97Nttt9 , 
74L&2S1N? 00 
74LS3S0V 44 
74LS3MN 7 Z 
74LSJK3N3.00 
74LS290N 1 7G 
T4LS393M1 76 
74LSJ90V7 JO 
74LS376V 62 

74L.S178N1 60 
74L53U9N 73 
74L61L70V3BS 


33 

{74H0BN 

48 

.74H73N 

60 | 

J4H1KN 

-3> 

liaiilDN 

,J2 

I74K74IV 

801 



SCHOTtKY TTL 



*4 

7*S f 1 

56 

7*964 

BO 

743114 

.00 

74530- 

.99 

746 7 4 

80 

743133 

.59 

746 30 

BO 

7*376 

1,16 

745116 

60 

74332 

BO 

7*5-11 J 

1 DO 

74S151 

SG 

7*‘:*o 

69 

7*3113 

1 50 

i*siau 


4001AE 3 
400JAE 3 
400tiAE 1.3 
4007 A E 2 
40C»At 1 * 
4009AE 5 
401O4E * 

40UAE 3 
40UAE 3 
41 > 1 3 A £ J 
4Q14AE t.3 
4 019 A E 1 : 
4019AE t 
401 7AC 1 t 
401PAE 1.3 
4Q19AE .5 
4030A E ■ 4 
4071 Af 1,3 
403 3 A E 1C 


4073AF 34 

407 4A Pi .9* 
4025At 34 


4D61AL 1 70 
4052aE 1 40 
4063*1 1.70 


4Q2GAE 7.60 4059Ab 1.06 


4027Af 53 4 058 AI 1 09 

*023At 1 GO «Q69 aC 3 ID 
40J9AE 1.20 4063AL 7 90 

*030 A E 44 4066Af 00 

4033*1 2 00 4063 AI 44 

*035 AC 1 30 4069 A E 44 

404QAE 170 4070BE 00 

4041 Al 1 35 4071Af 49 

4 0 4 J A L i 30 40 72 A £ ;<* 

40*3*1 95 4073*1 *0 

40*4 At 1 10 4075 AI 40 

404641 3 10 4076 A1 13* 

4047AI J60 4077AC 40 

464BAL 1.43 | 4D7fi A I 40 

4049A E 56 -UfflIUI 40 

4050 AI M I 4062 M M 


4003 A E 1 65 
4096UE 1 95 
40-J9AE 3 50 
4099AE 3 90 
45U2AC 1 50 
*503HE 60 
460710 E 2 20 
45 104 E 1 40 
45 1 1 rl IF 1 30 I 
461IBS 1 30 
4314M- M20 
451 ft A E 5 .00 


*U7 I *4 L 4.P ILMIPI'L ' VU 

*072 At 34 I 4515 A E 1 75 

407341 40 451BAE 1 50 


4520aE 1 VS 
4521AF 2 20) 
46Q9AE ? 05 
4901 *6 03 

*0 TIAf 32 


CONTINENTAL SPECI ALTlES 


r PROTO BOARDS A 

£ X PE RM E N T E RS 

&uild& S*tt cttcvUs at tilstm VOH thinkt 

P&C $1595 I PB103 $59.99 

PR 100 10.95 FEU CM 79 05 

PHI 91 2995 EX300 9 95 

F0.102 39.95 | EX600 1095 


PROTO BOARDS 

■kVi rfl built in rrgutMttrdshort-propf pcwer wpphtl 
76303 6V. 1 aTipf«Vu1ittd (fwv iupfiif $ 76,00 

PO20JA sv. 1 amp and 115V, H imp fa 4u i«t*d 120 00 

_ iup-AV _ 

LOGIC MONITOR \ LOGIC MONITOR 2 

SIri'ijnIf litplfvt Il*1l&.|i Ej 0‘tt'layi IT*11r *pfl 
mj uyfianm; ig^k mn [)l*;jl Httac of dhgiEjt iCi l-ueh m C 
DTL TtL. HTl &t CMOS :Z-1 WG3. MTL TTL.OTLNKTl 
DIP iCi fotk+i *if*. $74.96 »lsti*ciab>4 TMaihflld tonrroJ 

LOGIC PROSE LP-1 

CflmpKl, Circuit pr»*«id rrujl ti<un{ (Jem logic proU Multi 1 *ITIIty 
cOrneMiOlilcv, DTL/TTL/HTL/CMOS, fruit rogi^ r«v* | t *n<j D U stu 
at> dhgLuM Eiifuiirv 544.95. 


PROTO CLIP ..‘I. 

Tot potrr OnfrMYdl Air I^il trend DrJng 1C lf*H up |B 
from PC board mrlHt for fail ifOunU i^eoilnd 
PC 14 II pin *4 5C 

PC1E 1* pin 4,75 LflH 

PC 34 24 t»m 150 

PC4Q 40 pm 13.75 


SOCKETS & BUS STRIPS 

I ' - = . n -’lug ■ n.. nrra t#n, madi t v v , ( ipind vim >out patchcorm 
fl: ■ I O' l«l4*r Sniv tdgtmn lo farm breadboard nttdtH 
= r V PN/Dncfiglion Tarni'h Pr<« 

9 ; lll arFOSSaEkai 111 $12.50 

i 9,1 aT33Rflu<i 20 3.50 

1 ill QT4I3 S*h[A*1 9* 10.00 

I QT47S flu-i tfl 3,25 1 

! QTJ5SSo:k*t 7* fl SD 

■ QT353 Bui 12 2.00 

I 1 GT11S Sd-cHal 3G 4.75 

, GT126^0*Mt 3* 3.75 

<Lz -L.J liJ DTSSShtHti 16 3,J6 

QT7S Sectal 44 3.00 


BREAD BOARD JUMPER WtRE KIT 

Each art c<KFT* ri 350 rr-m cut to 14 
(tiflfrinl ItngHll trorri Q 1 TO 5.0 r r 
Each uvlra >i itripp*ij and Haiti art 
PtrtT 00° fqr tatv InjfM w Wl™ 
«|g r Led git 1 it elatirliad hy tciet coning 

_ _ AH W44 It lolld 1-inntf! 22 gtjpt witfh 

m * ' PVC ■n*>ulit3flA TM a cfiTi 

t* S 4 pack Ml «n a tonrtntnt plate fad* 

BK-t. , . . $9.95 


jflADIAL LEAOJ 


CARBON FILM RESISTORS (5M ALUMINUM 

On V it » Muttipla of t LECTROLVTIC 

too PTI prr v*iut fohmi) CAPACITORS 

KIV . . $ 1 .fi9 par 100 
XW .11,79 par 100 

TO 100 1 .OK 10K TOOK 1 OV J%| } 

11 110 1 tK TlK 11QK 1.1V fm^rnY ’ 

12 120 1 3K 12K 120K 1.2M _ 

13 130 1 3* 13K 130K \ 3M I ^ 

16 150 I IK 16C 160K 15V 

16 760 1 6K 76K 160K 1 6V ^ \ 

1* 160 1 6K 18K 160 pc. 1 8 V 

20 300 3 OX 20K 200K 2 OH 

22 220 3.2* 22K 230K 2 2M 

24 240 3 *K 24< 240K 2 4V iFIAOlAL LEAD] 

3 7 J70 J 7 K 37K 270* J.7M I 

30 300 3 OK 30K 300* 3 OM MFD 1QV 16V 25V 35V 50V 

13 330 3 3* 33 K 330K 3 3V I 13 .13 1* 15 15 

36 360 3 6K 3CK ItflK 9 0V ft 13 .14 17 2D J4 

39 330 3 0* 39K 330K 3 3V 10 .14 .15 IS 72 26 

43 430 4 3K 43K 430K 13M 23 ,15 .16 21 23 31 

47 470 * IK 47K 470* 4 7V 33 10 .17 J3 24 30 

ST S10 6 IK DTK 510* 6 1M 47 .17 .16 .34 J5 32 

56 560 fi 6K &6K 660* 5 6V i 100 IB ,20 20 30 35 

03 620 6 9K &JK 030* 6 2V 320 33 .25 .36 40 50 

66 &BQ 6 U K 60< 660* G BM 330 30 33 .40 46 55 

75 7S0 J *K ?6K 7$0* 7 5V 470 1$ *0 4ft 60 8D 

12 620 a JK 62K BiOK B JW 10OQ ,66 BO 1.30 

01 910 0 1* 9 IK 010* 0 1M 2300 -- 1 30 1 60 2.50 

RESISTOR ASSORTMENTS 

Each ati-oftmani contaki 5 p?i each pf iq diffaranl vi^ti 
Vaiu*i ihcruo*d act tMwn an fOhimi 
nw, ax too pc* tovl| .. $>.T5 
»W d a% (00 pa TOiall . . . $t 8S 

Aift.lj lO. 12. 15. IB. 23. 27. 23. 39 47, 5fi phm 

A ill. 2. Cfl. B2. 100. 120. 150. I BO. 220 270. 330 300 ahm 

Am. 3 4 70, SOD, 6BO, 920 ohm, 1 *, 1 J*, 1 &K r 1 6 K. 2 3K 2 7* 

Aifl.4 3.3K, 3,9 k, 4,7*, 5 0*. B BS, iJ 2* 1 , 10*. 13K. 19 k, 18* 
Alii, a 33* 27*. 33K 39*. 47K. 56 k 64* SJ* I DO* 1JQK 
Am. 6 150*. 7B0*. 230* 370* . $30* . 390*. 470K, 66QK 640* 
620* 

Am. 7 IV 1 2V l.SV. tJV .3 2V.j 7V.2J2V. 3 9« 4 tv % 6v 

A*1t-8R (Alt ipirtn ntartminii gL^>< 

Xw, ov 390 PCI Idial $10.05- 1 6S 350x,ci taiai S11,55 


MFD 

10V 

10V 

2!iV 

35V 

50V 

l 

12 


1* 

19 

16 

ft 

13 


.11 

20 

2* 

10 

14 


IB 

23 

30 

22 

15 


21 

73 

.28 

32 

10 


27 

2* 

30 

47 

1 t 

.18 

24 

29 

32 

100 

IB 

.20 

20 

30 

.38 

220 

23 

25 

.35 

40 

.50 

330 

30 

.33 

.40 

46 

.65 

*70 

25 

*0 

*9 

60 

.80 

1000 


—— 

.85 

80 

1.20 

2200 

_ 

-_ 

1 30 

1 GO 

2.50 



JANUARY SPECIALS 



MICROPROCESSOR CIRCUITS 


808 OA 

23 00 

T40JA 

■ 0 00 

P2102 1 

2.50 

A V 9080A 

34 95 

l 403 a 

1 00 

*>2102* 2 

5.20 

AV2O01DC 

31 00 

1404A 

3 00 

P-2J1 1 

360 

Cl 702A 

1 1 00 

1405A 

3 40 

P211 1 1 

4.SD 

AV29D3'C 

3 60 

2S»PC 

400 

f»2112 2 

4 80 

AV2909 P C 

10 10 

AVS 101A0C 

6 00 

P2405 

6.00 

AM2906^C 

11 20 

AM9101APC 

fi 00 

P3101 

4 00 

AVJ907PC 

S 75 

AM813QADC 

26 *0 

P3131A 

4.10 

AU290gPC 

29.9(1 

AV9140ADC 

28.40 

PS212 

3.6 Q 

AV291 tDC 

10 95 

P8101 

4 85 

AV3602PC 

5 SO 

AM2918PC 

6 *0 

P8102 

4 17 

AV2&04QC 

7.60 

AW2072QPC 

6 25 

PB1 1 S 

* 95 

AM 2 tOSt 1 C 

12.00 

AMJ9721PC 

6 25 

Pi 101A 

2 JO 

AVja02»C 

1 90 

*vtS5Di 

to OO 

P710I 

3 60 

AM3i04PC 

400 


V»Hd onty until J*<wk*y J7, 1977 



POWER S UPP LIES- AO TEC 14 


30 06 


60 40 


41.60 


Iplessey \ 

POLYESTER 

(CAPACITORI MINI BOX 

yf v s v* v i 

□01 TDOO 14 030 25D IS 

.0013 1000 14 0*7 350 1& 

0015 ItJOO 14 056 350 15 

.□016 1000 .14 060 J BO IS 

.0032 1U0D 14 0fl3 250 17 

.0027 1DQO 14 % 100 IT 

I .0D33 1000 .14 13 100 18 

□017 K3D 14 15 IDO 20 

.0047 AID .14 IS 100 .21 

.0069 630 14 22 100 .23 

.0000 630 I* J 7 100 Jfl 

□063 130 14 | 32 1DQ 3Q 

.01 630 14 39 TOO 33 

013 130 14 4? 100 36 

.□15 400 .15 56 100 .44 

.016 400 15 m 100 47 

023 400 15 62 100 M 

.027 4DD .15 10 100 GO 

.033 250 15 


PLESSEY SAMPLER 

300 VC TALI J6D CAPACITO RS C X nn 
IB Dlf f f MFNT STD VALUES flA&.UU 


L 15 PULSE/SWEEP FUNCTION GENERATOR KIT 

. FEATURES: l Hi it 100 KHa in 6 'mgn, at cw 

tTant aPhPlUvda - Sma and tiitngia to 

V • ••; JOvpp mtft 600 CfWt *Si«* d’iIVKW rl S\ 
» * ( ! Typical ♦ Vpllapa qdnfrgliad trr«H> fil nm ar>d Trl 

— ” angle wavti * TT L tquirf wivx hai a fully adjuitaol* 

pul«* and dnvn 600 oh mi * Fr*quaneMi of lowir 
(tun 1 Hi and ptutr than TOO kMi p* otiTa-n4bla * thprt prpol 
dompiat* with poyvar luppiy and matal rat* $55 DO 


CALIFORNIA CALIFORNIA 

ANCRGNA ANCMONA 

11CBC1 Jilfincn BFvd. 1300 E Etfingpr Avt 
Culvtt City, CA 90730 Sanla Ana, C A 9270$ 
1213)390-359$ (7141547-6424 


ARIZONA 
ANCRGNA 
4518 F tF-i -.kl rtAy 
Tuaon, AZ B5711 
16071 8HI 2348 


OHEGON 
ANCRONA 
1125 N.F B2nr| Avt 
(NmIUphJ. OR 9 7770 
RiOJI 254 5541 


CANADA. B.C 
ANCRONA 
5C5G Fraidi Si 
|V*r,em,y*I.BCV*W?Z4 
]*23l 324 0707 




T R ANSI STOH SPE C \ F 1C A TIONS 
MANUAL, 7|h Ed- 

No.21208.15.95 

FIRST CLASS RAOlOTELEPHONE 

LICENSE HANDBOOK. 4th Ed. 

No ?1144 .S7 50 

SFMICONOUCTOR REPLACEMENT GUIDE 
No .21092 . . $3 95 

aUlLOINO & INSTALLING ELECTRONIC 
tNTRUSlON ALARMS 

No. 20929. $4 50 

UNDERSTANDING 1C OPERATIONAL 
AMPLIFIERS 

No.ZOaSS * *.. , .* * $3.95 

HOW TO USE 1C LOGIC ELEMENTS, 

2nd Ed. 

Np.21081 $4,50 

UNDERSTANDING CMOS 
INTERGRATED CIRCUITS 

Nn 2H29__$4 9°. 


Digital Auto 
Clods 

Duild-lt-Yourseif 

Kit 


IJCW 74C00 

TT SERIES CMOS 


SOCKETS 

STANDARD, SOLDER. TIN ^ 

£ fi 

STANDARD, SOLDE R, GOLD 

% ft' 

Til RE WRAP, GOLD lLtv*l Np-3? 


1 74 

29-49 90 100 


1 24 

25 49 

50-100 


1-24 

35 *9 

90 100 

14 Pm 

0 27 

0 25 0 74 

6 Pin 

0 30 

0.27 

0 24 

10 Pm 

045 

0.41 

037 

16 Pin 

0 30 

0.27 0.25 

I* pm 

0.35 

0.32 

0.29 

14 Pin 

0.39 

0.35 

0.37 

IS Pm 

0 39 

0.32 0 30 

19 Pin 

0 33 

□ 35 

0.32 

16 Pin 

0 43 

0.42 

0 47 

2* Pm 

049 

0,45 0.42 

IB Pm 

0.52 

0 47 

0.4 J 

IB Pin 

0.75 

0.50 

0.6 J 

Jfl Pin 

090 

0 90 0 81 

24 Pin 

0.70 

0.93 

0 97 

24 Pin 

1 05 

0 96 

0 85 

36 P<n 

1 30 

1 26 1 15 

2B Pin 

1.10 

1 00 

0 « 

29 Pm 

1 40 

1.25 

1.10 

40 Pin 

1.69 

1.45 1 30 

38 Pin 

1.76 

1 40 

1-28 

2G Pm 

1-59 

1.46 

1.00 




40 Pin 

1.29 

f.59 

t 4$ 

40 Pm 

1 75 

1.59 

1-40 | 



LOW PROFILE, SOLDER. TIN 





8 Pin 

0.16 

0 IS 0 14 

16 Pin 

078 

0 J7 

036 

28 Pm 

0 44 

0 43 

0 42 

I* pm 

0 19 

DIB 0.17 

22 Pin 

039 

0 35 

034 

36 Pin 

0.69 

0.5B 

0.67 

16 Pin 

021 

020 0 18 

2* Pin 

0 37 

0 36 

0.39 

*0 Pin 

Q 63 

0.51 

060 


MATSUO 

DIPPED 

TANTALUM 

CAPACITORS 


Veninnam drdar S10 00. Add $1.00 io cow pottgga and handling, 
CaidDihia Ra-Mdthti add 6* u-n *j. Matt Did*' - SandChacL or 
mon#V Id P.U Bo» 220B$ C«H4f City. CA 9Q2Mi C00» 

LLjrtrar Chtffla inti 6>nt Art#IcJ^d WtKi^had (Sfriryf tto hot acerp f 

fH4r( or fibon* ofdtnj 


SAMS BOOKS 


TTL COOKBOOK 

No^l03$ $895 

1C OP AMP COOKBOOK 

NO20969. $1255 

SECOND CLASS RADIOTELEPHONE 
LICENSE HANDBOOK. 5TH Ed. 

N<j,21l11 . $750 

TRANSISTOR SUeSTITUTfON 
HANDBOOK. lSlh Ed 

. . $4.50 

REFERENCE DATA FOR RADIO 
ENGINEERS. 6th Fd 

No.21218. $30.00 

BASIC ELECTRICITYSEUECTRONICS SERIES, 
Vol.l BASIC PRINCIPALS AND APPLICATIONS 
No 201*7 $5 j5Q 

TV TYPEWRITER COOKBOOK 

.21313 _S9 9S 


FROM 


MF V 

1 39 

16 33 
22 36 
33 39 
47 39 
68 39 

1 0 3$ 

»J 39 

2 2 20 

2 2 39 

3.3 39 

4 J 36 


$ 

MF 

V 

$ 

33 

€ « 

10 
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XR FUNCTION 
GENERATOR 


XR-2206KA SPECIAL $16-95 


Includei rnonallthlc funclinr gen- 

vrttd# 1C, PC board, add AtfmbJy 

initiation manual 


XR 2206KB SPECIAL $26.95 
Sam* al XF1-2205KA and- inUudei 
ivrartul compo-rvantl JorPCboard 


74COON 3«f 
7*C0O2Ni 4Q 
74CO04N 60 

JacotEJN JO 
74C10N 00 

74C14S 2 30 

74C2DN 90 
74C30N 50 

T4C32N 00 
74C42H 2 10 

74048*1 330 

74CT3N 1 26 


74C74N 00 

74C76N 1 00 

74CB3N 2 75 
74C8&N 3 76 

74CSEN 1 00 
74C325 14 00 
74C00N 2 70 

74C93N J 60 
74C95N 1 a Cl 

7 * C107 N 100 
74C191N 340 
74C154N 6 10 


74C16TH 3 40 
74C16QN 3.10 
74C101N 2 10 
74C1WN 2 10 

74C1G3N 2 10 
74C1fi*f» 1 A0 
74C196N 1*0; 
74C173N 180 
74C174N 1 ?0 
74C176N I 10 
74C193N 2 10 
74C19IN 3,10 


T4C195N 160 
74C22IN 3 10 
T4C901N I 00 
74C003N 1.00 
74C903N 1 00 
74CP04H 1W 
74CP06N 1O0 
74CV0JN 100 
74C014N 2 70 
60CO5 100 

0OCD7 100 








































mastered one game, just 
switch to the next and try 
your luck* With two types of 
rifle shoot plus hockey 
(Photo 1), tennis (Photo 2, 
shown with the game 
switched to smaller paddle 
sizes}, squash (Photo 3), and 
practice to choose from, I'm 
sure you and your friends will 
be entertained for many 
hours. The AY-3-8500-1 MOS 
chip from General Instru¬ 
ments is a very versatile chip. 
By using a standard television 
(with an rf modulator circuit) 
or direct video output to a 
video monitor (or modified 
television), the games can be 
generated with minimal 
external circuitry. The MOS 
circuit is battery operational 
and has a low current drain of 
only 30 mA. 

Features 

Some of the features of 
this circuit are automatic 
scoring with a 0*15 score 
display on the TV screen plus 
the audio "bink/ 1 "bonk," 
and '‘being” sounds necessary 
for any professional video 
game. These are not optional 
features; they are included in 
the logic of the chip. 

The game can provide 
either 1.9 inch or .95 inch 
high bats on a 19 inch 
diagonal television screen. 
The bats can also be divided 
into two or four areas of 
deflection. In the two-angle 
mode, the top and bottom of 
the paddle determine the 



Photo 

angle of deflection. If the ball 
hits the top or bottom of the 
paddle, it will assume the 
angle of deflection and con¬ 
tinue in play. In the four- 
angle mode, the paddle is 
divided into four equal sec¬ 
tions. The quarter of the 
paddle which hits the ball 
defines the new direction for 
the ball. The direction does 
not depend on the previous 
angle at which the ball hit. 
With the two-angle mode, the 
top and bottom pairs of the 
paddle are summed together 



Photo 3 ; Handball. 



4. The completed (and compact) unit. 


and only the two shallower 
angles are used to provide the 
new direction for the ball. 

The ball can be re-served 
cither automatically or 
manually. In the automatic 
mode the ball will rc-serve 
after each score. With manual 
the game will stop serving the 
ball after each score is made. 
Ball speed is selectable from 
1.30 seconds to .65 seconds 
for the time taken by the hall 
to transverse the television 
screen. 

Pin Designations 

(I) No connection. 


(2) Ground. 

(3) Sound output. A hit is 
equal to a 32 millisecond 
pulse of 976 Hz. A boundary 
reflection will give a 32 milli¬ 
second pulse of 488 Hz, while 



Fig, 2 2 MHz oscillator that 
is included in the board lay¬ 
out , 


*vc z emeuir 



Fig. 3. Schematic for the rifle circuit . / ha ve not done any 
work on this circuit as of yet f so you are on your own. It looks 
pretty simple though ; and shouldn't give too much trouble . 
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RONDURE COMPANY 

Where We Ship from Inventory the Same Day Your Order Arrives 


AT THE LOWEST PRICE WE’VE EVER OFFERED! 

A SELECTRIC TERMINAL COMPLETE WITH RS-232/C INTERFACE AND CERTIFIED 
FOR MAINTENANCE BY A NATIONAL SERVICE COMPANY. SHIPPED THE SAME 
DAY WE RECEIVE YOUR CHECK* 


$ 895 — 


Specifications 

□ Size: 21” wide x 21” 
deep x 8” high. 

□ Power Input: 115 Volt, 
60 Hz, 

□ Mounting: Tabietap. 

□ Interface: RS232C* 

□ Weight: 54 lbs. 

□ Color: greyish beige; 
blue. 

□ Environment: Normal 
office conditions. 




We Buy and Sell the Following 
Equipment 


MINI COMPUTERS AND MICRO COMPUTERS 
FORMS HANDLING EQUIPMENT 
COMPUTER PERIPHERALS 
COMPUTER TERMINALS 


Bursters 
Tape Cabinets 
Disk Pack Cabinets 
Keypunch Desk 
CRT Tables 


NEW ADDRESS 
2522 BUTLER 
DALLAS, TEXAS 75235 
Phone: (214) 630-4621 


'MjmTenjEice limited to citiei in which invite now 
oHtredl Shipped the with day at certified check oi 
money ordtr limn When regutti check! ttcompiny 
Older, tquipmcnl ti ihipppd when rtfultr check 

ALSO NOTE NO EQUIPMENT INCLUDES 
PRINTS OR DOCUMENTATION fun 
left ittttrf), NO CONNECTING 
CORDS OR CONNECTORS EQUIP 
WENT IS SHIPPED ON AN AS IS - 
WHERE IS - BASIS. EXCEPT 
WHERE EXPRESSLY STATED IN 
WRITING NO REPRESENTATION 
OR WARRANTY IS MADE AS TO 
THE QUALITY. CONDITION OR 
WORKING ORDER OF ANY EQUIP 
MINT OH PART. 


PRINTERS, READERS, PUNCHES 
TAPE DRIVES, DISK DRIVES 

ACCOUSTICAL MODELS ORIGINATE ONLY 
USED - UNTESTED 

S20.OO ea. 2 for $35 


TERMS: Check or Money Order, For 
Modems. Bose, Keyboard, Switch Btk., 
add S2.00 shipping and handling. All 
others shipping packaging and shipping 
collect. 


BASE CASES FROM SELECTRIC MECHANISMS 
SUITABLE FOR MICRO/MINI OR TERMINAL 
BUILDING BLOCK $7.50 
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a score will give 160 milli¬ 
seconds of a 1.95 kHz tone, 

(4) Vcc, +6 to +7.5 V dc. 

(5) 2/4 angles input. When 
left open, two rebound angles 
are allowed (±20°). When 
connected to ground, four 
rebound angles are selected 
(±20°, ±40°). 

(6) Ball output. The ball 
video signal is output here. 

(7) Ball speed input. When 
left open, low speed circuit is 
selected at i.30 seconds, and 
when grounded, 0.65 seconds 
is selected. 

(8) Manual serve. When 
grounded, the play is re¬ 
started automatically after 
each score. When left open, 
the play stops after each 
score. The game can be re¬ 
started by connecting the 
input momentarily to ground. 
(9,10) Right and left player 
video outputs. 

(11,12) Right bat and left 
bat inputs. A resistor capaci¬ 
tor network attached to each 
of these pins controls the 
position of the respective 
players. 

(13) Bat size input. When 
open, small bats are selected. 
When connected to ground, 
large bats are selected. 

(14,15) No connection. 

(16) Sync out. Output for 
horizontal and vertical tele¬ 
vision sync signals. 

(17) Clock input. The 
2,00000 MHz master dock is 
connected to this pin. 

(18) Rifle L 

(19) Rifle 2. 

(20) Tennis. 

(21) Hockey. 

(22) Squash. 

(23) Practice. 

(24) Score and field output 
video signals. 

(25) Reset input. This pin. 
when grounded momentarily, 
will restart the game at 0-0. U 
is normally left open, 

(26) Shot input. Driven by 
the output of a monostable 
to indicate a shot has been 
fired for the rifle circuitry; 

(27) Hit input. This input is 
driven by the output of a 
monostable (.5 seconds) 
which is triggered by the shot 
input when the target is in 
the sights of the rifle. A 
positive pulse is needed. A 



Fig. 4 . Board layout. 


note on the rifle game: The 
score is displayed only after a 
hit has been registered to 
prevent the players from 
shooting at the score to get 
points. 

(28) No connection. 

Circuit Operation 

The circuit has two types 
of docks that can be used. 
On the board layout provided 
(Fig. 4), the crystal oscillator 
is used. The schematic of the 


oscillator can be seen in Fig. 
2, It is very simple, using two 
CMOS gales (IC2) for opera* 
tion. This circuit will give a 
very stable 2 MHz output for 
the game chip's timing func¬ 
tions. The optional dock is 
shown in Fig, 1. Its main 
advantage is a savings in the 
cost of the parts needed for 
construction. 

IC3 combines the various 
video output signals from IC4 
and outputs the composite 


signal through RI2. Q1 and 
associated circuitry provide 
the audio output. $4 Is an 
SPOT slide switch which 
grounds the base of Q1 (when 
in manual serve} so there isn't 
a steady ‘'being" when the 
ball leaves the playing field. 
R5 through R8 (plus C3 and 
C4) are used to position the 
players on the playing field. 

The rifle circuit, shown in 
Fig. 3, connects to pins 26 
and 27, 1 haven't constructed 



Photo 5 . Printed circuit hoard with components mounted . 
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"As the designer of the 
very first frequency 
counter, I congratulate 
you on a very neat design 
at an excellent price. 
Performance of this counter 
is really impressive...” 





R. K Dickey 

Professional Etectncal Engineer 
(Designer Of the world s first frequency 
courvier at Berkeley Scientific, 1949) 



Thank-you, Mr. Dickey. 

Thousands more who own Hufco frequency counfers proudly agree. 

Since 1974, Hufco has made counters and "counter-offers' that satisfy people to no end. The 
Hufco combination-a rock-bottom price and sky-high quality—is proving a very popular duo. 
Here are three good examples why: 


A 500 mHz (6-digit) frequency 
counter for under 40 cents per mHz! 



No wonder people 
respect the Hufco name. 


Figure it out, ll adds up to unheard-of savings. With guaranteed 
quality to match anc exceed the overpriced brands Let us 
prove it to you today 


169.95 


(500 mHz kit) 

S199.95 assembled 


Incidentally, you’ll also find it on 
economically-priced digital display 
adapters, voice-operated 
transmits, power mike adapters, 
CB/Ham timers, and more. 


Interested? 

Rush us this coupon today. 


A 30mHz or 250mHz (6-digit) 
frequency counter — proven best 
sellers! 


69.95 

(30mHz kit) 

$99 95 assembled 

119.95 

(250mHz ktt) 

$139 95 assembled 



Please send me: 


500 mHz frequency counter - 1G9 95 kit 199 95 assembled 
iEnclose check o r money order . 

250 mHz frequency counler - 119 95 kiM 39 95 assembled 
Enclose check o- money order i 

30 mHz frequency counter * 69 95 ktt.99 95 assembled 
Enclose check or money order i 

Information on other handy Hufco products. 

Name ______ 


Address_ 

C ty Slate /.p. 


Mail to: 


• Box 357, Dept. R, 

nUTCO Provo, Utah 84601 801/375-8566 





this portion of the game, but 
it looks pretty straight¬ 
forward. A Darlington tran¬ 
sistor detects the ball on the 
screen of the TV. Coinci¬ 
dence of the ball (output of 
the photo transistor) and a 
trigger pulse results in a hit 
pulse being input to pin 27 of 
IC4. The shot pulse provided 
by IC1 and IC2 goes to pin 
26. The RC network for IC2 
should be chosen for an 
output of .5 seconds. 

Construction and Circuit Lay¬ 
out 

Any type of construction 
can be used: PC board, perf- 
board, or wire wrap. I put my 
unit in a 7x5 plastic box from 
the local Radio Shack store 
(see Photo 4). The PC board 
layout shown in Fig. 4 will 
work quite well. While in¬ 
stalling parts on the board, 
good construction practices 


should be observed to prevent 
any mechanical or electrical 
complications. Use Fig. 5 to 
install the parts and make 
sure all ICs are oriented in the 
proper manner. With proper 
construction, the game 
should work the first time it 
is turned on. 

One problem was encoun¬ 
tered: The audio sounds pro¬ 
duced tearing in the picture 
when used with my version of 
an rf modulator. This was 
solved by putting a capacitor 
in series with the video out¬ 
put to smear the lines slightly 
so they wouldn’t go "squig¬ 
gly" when a sound was 
produced. Adjusting the mod¬ 
ulator bias helped a lot also. 
Any of these audio problems 
can be effectively solved by 
using the proper type of 
modulator. I also suggest a 
three wire system for the 
controls. With the left and 


right player controls floating 
(neither side at ground poten¬ 
tial), they will pick up noise 
and possibly prevent a good 
visual display. By three wire, 
I mean two for the pot with 
an outside shield going to 
ground. Grounding the metal 
chassis of your project is also 
recommended. 

Photos 5 and 6 show the 
completed PC board and the 
completed unit with PC 


board installed. 

Displaying the Game 

When the chip is received, 
information may be enclosed 
on building an economical 
VHF modulator. But be 
advised that not all modula¬ 
tors meet FCC regulations. 
Therefore, if you do decide 
to construct your own, make 
sure it meets the applicable 
regulations. Fig. 6 is a sche- 

vcc 



Fig. 6. VHF modulator ; NOTE: This modulator circuit is 
provided for test purposes only and may not possess the 
long-term stability or meet FCC requirements for home use . 
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SLEP 1$ 

ELECTRONICS sHH >ptS> 


ATLAS 

21 OX SO THRU 1 OM.$079.00 

215X160 THRU 15M.679,00 

21 OX OR 215X WITH NOISE 

BLANKER.719.00 

AC CONSOLE 220CS WITH VOX/SEMI 

BREAK-IN CW .. 104,00 

AC CONSOLE 220CS 147.00 

PORTABLE AC SUPPLY 200PS .... 100.00 
DMK PLUG IN MOBILE MOUNT, WITH DC 

CABLE. ...... .,.48.00 

DCC BATTERY CABLE .12.00 

DD-6B DIGITAL DI AL.229 00 

MT 1 MOBILE ANTENNA MATCHING 

TRANSFORMER ..27.00 

PC 120 NOISE BLANKER CONVERSION 

KIT , . ,.. . 52.00 

VX 5 VOX CONVERSION KIT FOR AC 

CONSOLE .49.00 

206 AUXILIARY VFO WITH EXTENDER 
FREQUENCY COVERAGE FOR ALL 
ATLAS TRANSCEIVERS...299.00 


DRAKE 

R 4C RECEIVER 160-10M .. , 599.00 

4 NB NOISE BLANKER R-4C.70,00 

FILTERS 250HZ, 500HZ, 1.5H2 . ea 42.00 
SPR 4 RECEIVER ... 629.00 

5 NB NOISE BLANKER SPR 4 . 70.00 

QC PC 12V POWER CORD.5.00 

SCC 4 100H2 CALIBRATOR . 20.00 

CRYSTAL KIT AMATEUR BANDS . . 31.20 
SSR 1 GENERAL COVERAGE RECEIVER 

.5 TO 30MH2 .. . . ... 350 00 

DC-PC SSR 1 DC POWER CORD.5.00 

T 4XC TRANSMITTER 160 10M , . . 599.00 

TR 4C TRANSCEIVER 80 1 OM _ 599,95 

34PNB NOISE BLANKER TR-4C . . 100 00 

MMK 3 MOBILE MOUNT .7 00 

RV-4C REMOTE VEG TR-4C ... 120.00 

AC-4 POWER SUPPLY FOR ALL DRAKE 
TRANSMITTER TRANSCEIVERS . . 120.00 
OC 4 12V DC MOBI LE POWER 

SUPPLY.,.135.00 

TR 33C 2 METER FM TRANSCEIVER 12 

CHANNELS .. 229.95 

AA 10 10 WATT 2 METER AMPLl 

F|£r . 49.95 

AC 10 POWE R SUPPLY TR 22, V R 33, 

TR 72 . 49.95 

MN 4 ANTENNA MATCH BOX ..,110.00 
MN 2000 ANTENNA MATCHBOX . 220 00 

MS 4 SPEAKER. 24.95 

W 4 WATTMETE R 1 B TO 54MH2 . . . 72-00 

7072 HAND HELD MIKE .19.00 

7075 DESK TOP MIKE WITH VOX 

SWITCH. 39.00 

RCS 4 REMOTE CONTROL ANTENNA 

SWITCH , . . .. 120.00 

HS 1 HEADPHONES.10.00 

TV 3300LP LOW PASS FILTER .... 19.95 

DSR 2 VLF-HF DIGITAL 

RECEIVER . 2,950,00 


TEMPO 

TEMPO ONE. 5 BAND SSB TRANS 

CEIVER , , , ,.... . 399.00 

TEMPO ONE AC POWER SUPPLY . . . 99.00 
TEMPO VF/ONE EXTERNAL VFO . 109 00 
TEMPO DF D/ONE DIGITAL DISPLAY 

TEMPO ONE .. . .189,00 

TEMPO 2020 SSB/AM TRANSCEIVER 80 

TO 10M 115V/12VDC P/S.. . . . 759.00 

TEMPO FMH 2 METER, 6CH HAND HELD 

FM TRANSCEIVER .199.00 

TEMPO VHF/ONE SYNTHESIZED 
DIGITAL READ OUT 2 METER 10 WATT 
TRANSCEIVER, NO CRYSTALS TO 

BUY ..... . 495.00 

TEMPO SSB/ONE SSB ADAPTOR FOR 

UHF/ONE . 225.00 

TEMPO 130A10 130 WATTS OUT 10W 

DRIVE. 17900 

TEMPO B0A1 Q 80 WATTS OUT 1 QW 

DRIVE . __. . . . ...139.00 

TEMPO 50A10 50 WATTS OUT 1 0W 
DRIVE.99 00 

TEN TEC 

TRITON IV MODEL 540 TRANS¬ 
CEIVER . 699.00 

252G POWER SUPPLY .99,00 

252G POWER SUPPLY/VOX 129.00 

207 AMMETER. -.14.00 

245 CW FILTER .25.00 

ARGONAUT MODEL 509 . 329,00 

405 LINEAR AMPLIFIER.159,00 

210 POWER SUPPLY 1 AMP.27.50 

251 POWER SUPPLY 9 AMP.79.00 

206 CRYSTAL CALIBRATOR. 26 95 

208 CW FILTER .29.00 

HR5A KEYER . 38.50 

KR20A KEYER .67.50 

KR50 KEYER . 110.00 


BRIMSTONE 

MODEL 144 2 METER FM TRANSCEIVER 
25 WATT 143 TO 149.99MHZ DIGITAL 
DIALED 5KHZ STEPS, NO CRYSTALS TO 
BUY 142MHZ MARS COVERAGE 
OPTIONAL . 660,00 


COMCRAFT 

CST 50 VHF TWO BAND TRANSCEIVER 2 
AND 1% METERS. DIGITAL FREQUENCY 
SYNTHESIS 142 TO 149.995MHZ AND 220 
TO 225 MHZ 25 WATTS .. 869 00 


SHU RE 

526T DESK TOP MICROFHONE WITH 

PRE AMP -.-.*... 36.80 

444 SSB DESK TOP MICROPHONE WITH 
OFF-ON VOX SWITCH PTT ........ 34.50 

404C H IGH IMPEDANCE MAGNETIC 
HAND HELD MICROPHONE FOR SSB PTT, 
IDEAL FOR SWAN. ATLAS.27,00 


MILLEN 

92200 ANTENNA MATCHBOX ALL BAND 

2KW.. ...- , . 199.00 

92201 JR ANTENNA MATCHBOX ALL 

BAND 300 WATTS . 138.00 

90652 SOLID STATE GRID DIP OSC*L 
LATOR 9 VOLT BATTERY OPERATED 
WITH COILS 1.7 THRU 300MHZ 
SUPPLIED.138.00 

SWAN 

700CX TRANSCEIVER , , .. 649.95 

117XC CONSOLE SPKR/PS .159.95 

14 11 7 DC MOBI LE P/S ..189.96 

510X CRYSTAL OSCILLATOR .67.95 

VX-2 VOX...44.95 

FP I PHONE PATCH . . 64.95 

SWR-1 POWER/SWR METER 01 KW, 3,5 
150 MHZ SO 239 CONNECTORS .... 21.95 
WM 2000 IN LINE WATTMETER SCALES 

TO 2KW. 49,05 

1200X LINEAR AMPLIFIER 1200 

WATTS . 349.95 

MARK II LINEAR AMPLIFIER 2KW 849.95 

SS 1GB KIT .99.95 

45 ALL BAND MANUAL SWITCHING 1 KW 

PEP MOB! LE ANTENNA .11 4.95 

742 TR1 BAND 20 40 75 METER ELEC 
TRONICALLY TUNED AUTOMATIC 
BAND SWITCHING, 500 W.PEP .... 79.95 

REGENCY TRANSCEIVERS 

HR-312 FM 2 METER 30W. 269 00 

HR 6 FM 6 METER 1 5W. 229.00 

HR 220 FM 220MHZ 10W . .... 239.00 

HR 440 FM 440 MHZ 10W ........ 349,00 

P-U0 AC P/S 117V/12VDC REGULATED 5 
AMP. 49,95 

NYE VIKING 

CODE KEYS SPEED X MODEL 114 310 003 
STANDARD KEY, NICKEL PLATED 

HARDWARE WITH SWITCH .8.25 

MODEL 114 310 004 STANDARD KEY, 
NICKEL PLATE HARDWARE WITH 

SWITCH AND NAVY KNOB.9.10 

SSK 1 DUAL PADDLE SQUEEZE KEY 

NICKEL PLATED.23.95 

MODEL 1 74 404 002 CODE PRACTICE SET 
WITH KEY, OSCILLATOR. AMPLIFIER 2* 
BUILT IN SPEAKER HEAVY DUTY BASE, 
TAKE 9V BATTERY, NOT 
INCLUDED. 18.50 

BEARCAT 

MODEL 101, 16 CHANNEL SCANNER f 

30 50MHZ 146-174MHZ, 416 512MHZ, NO 

CRYSTALS TO BUY... . 290 00 

W2AU BALUN. 2KW PEP, 3 TO 40 MHZ 1:1 
MATCHES 50 OR 75 OHM UNBALANCED 
COAX LINE TO 50 OR 75 QHM BAL 
ANCED LOAD, BUILT-IN LIGHTNING 
ARRESTOR.12.95 



P.0, BOX 100, HWY, 441, DEPT. 73, OTTO, NORTH CAROLINA 28763 


WE PAY SHIPPING VIA U.P,S. OR BEST 
WAY ON ALL ADVERTISED ITEMS; 
TRADES TAKEN ON NEW EQUIPMENT, 
WRITE FOR SPECIAL PACKAGE PRICE 
ON COMPLETE STATIONS. SATISFAC* 
TION GUARANTEED, WE ACCEPT 
MASTER CHARGE. N,C. RESIDENTS ADD 
4% SALES TAX. PHONE BILL SLEP 
704-524-7519 MONDAY THRU FRIDAY 
8:30-6:00 PM, 
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Photo 6 . interior view of the completed unit (The cases for the paddle-control pots ore 
waterproo f a mm unit ion cases,) 

matic of a modulator 1 built regard to direct video into a Don Lancaster's latest book 
for testing the unit. With standard television receiver, entitled TV Typewriter Cook¬ 


book is a handy reference on 
video interfacing. I recom¬ 
mend readi ng this book i f 
you want a good under¬ 
standing of television conver¬ 
sion principals, as well as a 
good understanding of TV 
typewriters. Many practical 
applications are included 
which will be applicable to 
this game. And, of course, the 
game has direct video output 
(with no modification neces¬ 
sary} to any video monitor. 


Conclusion 

So here it is, a new kind of 
“pong” chip. It is one of the 
first of its kind available to 
the hobbyist. In the near 
future there will probably be 
many more. Look how the 
microprocessor chips started 
out and how quickly the idea 
caught on. The AY-3-8500-1 
chip may be obtained from 
MHz Electronics, 2543 N. 
32nd St., Phoenix AZ 85008, 
phone (602) 9 57-078 6, 
$29.95.» 


ALDELCO COMPUTER 
CENTER 
NOW OPEN 


Kits, Books, Boards, Magazines 
Special 2102L1 8 for $17.50, We 
stock OK Battery Operated Wire 
Tool $34.95, OK Hand Wire 
Wrapped Tool $5.95. 7400 ICs 
CMOS, Timers PLL's. AM kinds of 
transistors, rectifiers, and diodes. 

Pius other electronic parts. 

ZENERS 

iNMftfo IN7S9400 Mw ea 35 1N473B To <N47G4 I w . , . 23 


Cl06B SCR.$.6$ 

MPSAH .. H JO 

2N3055 . 99 

umt>2FET . 45 

2N30O4 vrVimS .... 10/99 
2M549Bo<-?Nei08 . . 35 

MJE34CH2N5G55}.1.10 

40&V3 RCA FET.1.55 

7-tI or 70914Pm DIP 35 

555 Tirner . ,. , 75 

556 Dual 555. .1.75 

200 Vnlt 25 Arnp Qrkigei . 1.&0 
1N914 1TJ4I4S 15 lor 09 
1N34- UV60- 1N64 10 for .93 


CA 3036A Oir. Amp.Si.50 

LMSQIOpAmp 55 

LM309K Volt ficr, .1.10 

LM360N Audio Ajnp 1 75 

NC54GL Power Driver , , . 5.05 
NE5610PU . AM 

NE 5639 PUL.4 95 

NE565APLL . .3 50 

LM709 Min DIP Op Anp . 45 
LM741C£T05OpA«iji 45 
14 pr 15 Pul 1C SdcfceH.30 


We hive 7400 writs, ICs; xmd 
rljmp Ipr 


Send for our catalog. Open 
Mon thru Sat 9 am to 5 pm — 

Wed till 9 pm. 

We quote on any device at any quantity. Min r 
order $6,00, Out of USA send certified check 
or money order. Add 5% for shipping. 


0IEI1] 


2281A Babylon Tnpk Merrick, N.Y. 11568 
{516J 378-4555 


MODULES 
FOR ALTA IR AND 
1MSAI COMPUERS 


8K STATIC MEMORY - KIT S29S 
ASSEMBLED $375 
16K STATIC MEMORY - KIT $650 
ASSEMBLED S 775 
WIRE WRAP BOARD - KITS 39 
EXTENDER BOARD W/C - S 30 
BATTERY BACK-UP BOARD 

less batteries — KIT S 55 
115V I/O BOARD - KIT $149 
ASSEMBLED 5200 

THE 115V I/O BOARD MAS FOUR INPUI5 AND 
FOUR OUTPUTS EACH 1ISVAC AT I 5 AMPS. NO 
LONGER A NEED IOR RELAYS WITH THIS FOARD. 

32K DYNAMIC RAM - KIT $ 895 
16 K DYNAMIC RAM - KITS599 

Td order send check or money ordr^r (include 
52.50 shfpptrtg/harKlUng) to ELECTRONIC ENG. 
5 PRODUCTION SERVICES, fit-* 2 f Louisville, 
Tennessee- (Tn. users 4dd 6* sales tan) 
{ 6151984-9640 


□ o □ □ n ENIGMAS-1 □ □ □ □ □ 

Computer Games in BASIC 


Enigmas ! is a book of computer 
games taken from my catalog. 
The programs in this book are: 
GONE FISHING - Go fishing to 
make money 

CONCENTRATION - Match the 
hidden numbers — two can play 
SLOT-MACHINE — It's easy to 
lose your money 

CRAPS DICE GAME WITH DICE 
PRINT-OUT — Shoot craps and 
see the dice 

TANK ATTACK - Try to defend 
yourself 

STARSHIP (STAR TREK TYPE 
GAME} — Shoot some Klingons 
SHERLOCK HOLMES LOGIC 
GAME — Chase Professor 


Moriarty 

All my programs in Basic have been 
written to run in most any Basic 
co mp 1 1 er-tnt erpreter without any 
changes. 

They will run under Altair 4K or 8K 
Basic and most any other Basic com¬ 
piler-interpreter provided you have 
enough memory to run them. 


PRICE: 58.00 ppd.SORRY NO CODs 

B. EmcksON P.0. Box HOOD, 
Chicago 1L 6061 1 

□□□□□□□□□□□□□□□□ 
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FAX MACHINE BY DATAFAX 

We have transmitters and receivers. Used for weather charts, hi speed teletype 
recording. Normally used over the phone lines. Operational when removed 
due to upgrading of equipment. Only a few on hand and sold “AS IS." When 
used over the phone lines from weather data system, will draw full map of the 
US with cloud cover and also pressure gradients. Due to the weight of these 
machines they must be shipped via truck as they are around 60 lbs. Made for 
desk top use. Made by Stewart Warner Elect. Picture is typical unit. When 
ordering state receiver or transmitter. #FAX FOB Lynn Mass. 

$75.00 


GENERAL PURPOSE POWER SUPPLY 

A well designed transistorized regulated power supply with many uses. Each 
voltage adjustable by a pot. Each voltage I used. 115 volts AC 60 cycle input. 
Output (minus) 12 volts at 1/3 Amp, 12 volts (plus) at 3 Amps, 6 volts at 1 
Amp . . . three output voltages. Many uses ... as battery charger, op amp, 5 
volt logic supply, operate your car radio or tape player, CB set, in the house, 
etc. A commercially built regulated supply for far less the price of a kit. 
Shipping wgl. 101b. #SP-152-L $17.50 


Mi 




PARITY DETECTOR 

New packaged, made for RCA, detects even or odd 
parity, baud rate 110, 150 or 134.46, Built-in logic 
supply for the ICs, operates from standard 115 Vac. 
Control panel allows manual or automatic reset mode 
of operation. Aluminum enclosure (not shown) 
covers the electronics, TTY compatible. Ship wt. 10 
lbs, 

$12.50 


shown actual size 


ZENER 15V 63 Watt $1.00 
2.5 Amp 1,000 piv 

diode _4/$1.00, 25/$5 

Motorola 1N4001 diode 1A, 
50 piv____ 20/$1.00 


SILICON 

SOLAR 

CELL 


SOLAR CELLS 

Designed for the space program, these are the highly efficient 
silicon high output cells. Used for powering equipment, charging 
batteries. Made by Ion Physics Corp. Each with spec sheet. 

Size .394 x .788" 65 mA, .43 V $1.25 12/512.00 
Size .788 x ,788" 125 mA, .43 V $1.60 12/515.00 


RT 70/GRC as written up in 
73 Magazine, November, 
1976. Only $20.00. 


Please add shipping cost on above, 

FREE CATALOG SP-9 NOW READY 

P.O. Box 62K, E. Lynn, Massachusetts 01904 












21L02-1 RAM 

500 N. S. 

_ 8 for $12.95 

82S129-256x4 PROM 

Bl - POLAR-FAST! 

_ $2.50 _ 

8080A CPU CHIP 

$19.95 By AMD 

ZILOG 

Z-80 CPU CHIP 

_ $69.95 _ 

MM5204 4K EPROM 
_ $7.95 _ 

Sr Dr SALES COr ^ oTN£ R pAG£ f 

P. O. BOX 28810 - see terMS 

DALLAS, TEXAS 75228 




S.D. SALES CO. 


P.O. BOX 28810 -K 
DALLAS, TEXAS 75228 


Z—80 CPU CARD KIT 
FOR IMSAI/ALTAIR 


$149: T 


brou 9ht you the £89.95 4K RAM kit. We were not the first to 
an !5 5A !^ L T A * R compatible Z—80 card, but we do feel that ours has the best 
design and quality at the lowest price. 

advanced features of the Z—BO such as an expanded set of 150 Instructions, 8Q80A 
c ° m P a yplJlty, and operation from a single 5VDC supply, are all wen known, what 
JH™® 5 °^ r carcl d,, K' en * s 'tl* exua care we took fn the hardware design. The CPU card will 
5™?! °P a " s Ml sUt ®' fl ‘ so generate TRUE SVNC on card, to insure that the rest of 
Y*?P r system funcUon* properly. Dynamic memory refresh and NMI are brought out for your 
use. Bet eve it or not, not all of our competitors have gone to the extra trouble of doing this, 
hiynf ways “ s ^ 1 * n 5* udes P Jf- ts, all sockets, and complete Instructions for ease of assem- 
Ziui our Past experience with our 4K kit we suggest that you order early. AM orders 

will be shipped on a strict first come basis. Dealers Inquiries welcome on this Item, 

Kit shipped with 2 MHZ crystals for existing 500NS memory. Easily modified for faster RAM chips when the prices 
come down. Z—80 Manual — $7.50 Separately. 

Kit includes Ziiog Manual and all parts. 


JUMBO 

LED 

CAR 

CLOCK 


$16.95 

KIT 


You requested it! Our first DC operated clock kit. 
Professionally engineered from scratch to be a DC 
operated dock. Wot a makeshift kluge as sold by others. 
Features: Bowmar 4 digit .5 inch LED array, Mostek 
50252 super dock chip, on board precision time base, 
12 or 24 hour real time format, perfect for cars, boats, 
vans, etc. Kit contains PC Board and all other parts 
needed (except easel, 50,000 satisfied clock kit cus¬ 
tomers cannot be wrong! 

FOR ALARM OPTION ADD $1.50 
FOR XFMR FOR AC OPERATION ADD $1,50 


60 HZ CRYSTAL TIME BASE FOR DIGITAL CLOCKS 
S.D. SALES EXCLUSIVE! 

KIT FEATURES: 

A. 6QH2 output with accuracy comparable to a digital watch. 
8. Directly interfaces with all MOS Clock Chips. . 

C. Super low power consumption. (1.5 ma typ,) S5.95 Or 
0. Uses latest MOS 1 7 stage divider 1C, 2/$10. 

E. Eliminates forever the problem of AC line glitches. 

F. Perfect for cars, boats, campers, or even for portable clocks 
at ham field days. 

G. Small Size, can be used in existing enclosures. 

KIT INCLUDES CRYSTAL, DIVIDER 1C, PC BOARD 
PLUS ALL OTHER NECESSARY PARTS & SPECS 


50HZ CRYSTAL TIME BASE KIT - $6.95 
All the features of our 6DHZ kit but has 50HZ output. For use 
with clock chips like the 50252 that require 50HZ to give 24 
hour time format. 


a 


THIS MON TH'S SPEC I A LSI 
300.00 KHZ CRYSTAL - $1.50 
8080A - CPU CHIP by AMD - $19.95 
82S129 - 256 x 4 PROM - $2.50 
N.S. 8865 OCTAL DARLINGTON DRIVERS 
3 for $1.00 

Z-80 - CPU by ZILOG - $69.95 
MM5204 - 4K EPROM - $7.95 
Prices in effect this month ONL Y! 


1 

Q 


4K LOW POWER RAM BOARD KIT 
THE WHOLE WORKS - $89,95 

tmsai and Altair 8030 plug in compatible. Uses low power 
static 21LQ2—1 500ns. RAM's, which are included. Fully buffer¬ 
ed, drastically reduced power consumption, on board regulated, 
all sockets and parts included. Premium quality plated thru 
PC Board. 


SIGNETICS ANALOG MANUAL -$5.95 

Just out I From the acknowledged leader in linear 
technology. Theory, applications, and specs, on op 
amps, timers, phase locked loops, etc. 637 pages. 

A MUST For Any Technical Library! 


STICK IT! 
in your clock 
in your DVM, etc.! 


Huge Special Purchase 
Not Factory Seconds 
As sold by others! 


$3.95 



4 JUMBO ,50'* 

DIGITS ON 
ONE STICK! 

(with colons and 

AM/PM Indicator) BUY 3 for $10. 

BOWMAR 4 DIGIT LED READOUT ARRAY 

The Bowmar Opto-Stick. The best readout bargain we have ever 
offered. Has four common cathode jumbo digits with all seg¬ 
ments and cathodes brought out. Increased versatility since any 
of the digits may be used independently to fit your applications. 
Perfect for any clock chip, especially direct drive units like 
5038G or 7010. Also use in freq. counters, DVM's, etc. For 12 
or 24 hour format. 


UP YOUR COMPUTER! 

21 L02—1 IK LOW POWER 500 NS STATIC RAM 
TIME IS OF THE ESSENCE! 

And so is power. Not only are our RAM'S faster than a speeding 
bullet but they are now very low power. We are pleased to offer 
prime new 21L02—1 low power and super fast RAM's. Allows 
you to STRETCH your power supply farther and at the same 
time keep the wait light off. B for SI 2,95 


HOUSE NO. TTL 

7400 - 8/SI .00 7420 -8/$1.00 74141 - 3/Sl.OD 

7404 - 8/$1.00 7437 - 5/SI .00 74153 - 3/SI .00 

7408 - 8/SI .00 7438 - 5/$1.00 

Please specify that you are ordering House No, TTL 


WESTERN DIGITAL UART 
No. TR1602B, 40 pin DIP 
This is a very powerful and 
popular part. 

NEW—S6.95 with data 
LIMITED QUANTITY 


\ P 


RESISTOR 

ASSORTMENT 

% W 5% and 1 0% 
PC leads. A good mix 
of values, 200/S2. 


FAIRCHILD BIG LED 
READOUTS 

A big .50 inch easy to read 
character. Now available In 
either common anode or 
common cathode. Take your 
pick. Super low current drain, 
only 5MA per segment typ¬ 
ical, 

FND 510 Common Anode 
FND 503 Common Cathode 
PRICE SLASHED! 59c each 


TERMS: 

Money Back Guarantee, No 
COD, Texas Residents add 5% 
tax. Add 5% of order for 
postage and Handling, Orders 
under $10, add 75c, Foreign 
orders: US Funds ONLY! 


ip 


SLIDE SWITCH 
ASSORTMENT 
Our best seller. Includes 
miniature and standard 
sizes, single and mufti* 
position units. All new, 
first quality, name 
brand. Try one package 
and you’ll reorder 
more, SPECIAL 12/$1, 


MOTOROLA POWER 
DARLINGTON 
Back in Stock! 

Like MJ3G01. MPN 80V, 1 QA. 
HFE 6000 TYP. TO-3 case. 
We include a free 723C volt 
reg, with schematic for power 
supply. SPEC! AL'S 1.99 


CALL YOUR BANK 
AMEflICARO OR MASTER 
CHARGE ORDER IN ON 
OUR CONTINENTAL 

UNITED STATES TOLL 
FREE WATTS: 

1-800-527-3460 

Texas Residents Call Collect 

214/271-0022 


S.D, SALES CO. 
P.O. BOX 28810 K 
Dallas, Texas 75228 




























BUILD YOUR LIBRARY 



COMPONENT 
TESTERS 
Build your own test 
equipment and save a 
bundle (ami have a lot 
of fun), Volume 1 of 
the 73 Test Equipment 
Library shows you how 
to build and use transis¬ 
tor testers (8 of 'em), 
three diodes testers, 3 
IC testers, 9 voltmeters 
and VTVMs, S ohm- 
meter. 3 inductance 
meters, 9 capacity 
meters, and a raft of 
other gadgets for check¬ 
ing temperature, crys¬ 


tals, Q, etc, S’L9^ 


RADIO FREQUENCY 
TESTERS 

This is of more 
interest to hams and 
CBers , , . test enuip- 
men! you can build for 
checking out transmit¬ 
ters and iceel verst 
signal generators, noise 
generators, crystal cali¬ 
brators, GUOs, dummy 
loads . . . things like 
that. This is Volume 3 
of the 73 Test Equip¬ 
ment Library fPrepub- 
llcaUon offer) $4,95 


AUDIO FREQUENCY 
TESTERS 

If you’re into audio 
. . . such as digital cas¬ 
sette recording, RTTV, 
Baudot vs ASCII, 
5STV, SSB, Touch tone 
or even hi-ft . . . you'll 
want to have this book 
full of home built lest 
equipment projects. 
Volume H (Prepubliea* 
tion offer) $4.95 


microcomputer dictionary 

Over 5000 definitions and explanations 
of terms and concepts C704 pages) relating 
to microprocessors, microcomputers and 
microcontrollcTS. 
There are also sepa* 
rale appendices on: 
programmable calcu¬ 
lators; math and sta¬ 
tistics definitions; 
flowchart symbols 
and techniques; 
binary number sys¬ 
tems and switching 
theory; symbol charts 
and tables; summaries 
of BASIC FORTRAN 
and A PL. In addition 
there is a comprehen¬ 
sive electronics/com¬ 
puter abbreviations 
and acronyms section. 
$15.95 


MICROCOMPUTER 


m 



What To Do After 
You Hit Return 
PCC's first book of computer 
games . ., 48 different computer 
games you can play in BASIC — 
programs, descriptions, muchly 
illustrated. Lunar landing, Ham¬ 
murabi, King, Civil 2, Cubic 5, 
Taxman, Star Trek, Crash, 
Market, etc. $8,95 pp. 


WHAT to DO 
ABU YOU HIT 
RETURN 




VHP ANTENNA HANDBOOK 
The NEW VHP Antenna Handbook details 
the theory, design and construction of hun¬ 
dreds of different VHP and UHF antennas . . . 

A practical book written for the average 
amateur who takes joy in building, not full of 
complex formulas for the design engineer. 

Packed with fabulous antenna projects you 
can build. $4,95 

BASIC . , * by Bob Albrecht , etc. 
Self-teaching guide to the com¬ 
puter language you will need to 
know for use with your microcom¬ 
puter. 324 pages. $4,95 pp. 


Computer Programming Handbook 
A complete guide to computer programming 
and data processing. Includes many worked out 
examples and history of computers, $8.95 


WEATHER SATELLITE HANDBOOK 

Simple equipment and methods for 
getting good pictures from the weather 
satellite. Antennas, receivers, monitors, 
facsimile you can build, tracking, auto¬ 
matic control (you don't even have to 
be home). Dr. Taggart WB8DOT $4.95, 


RF AND DIGITAL TEST 
EQUIPMENT YOU CAN BUILD 

RF burst, fund ton, square wave generators, 
variable length pulse generators — 100 kHz 
marker, i f and rf sweep generators, audio osc, 
af/rf signal injector, 146 MHz synthesizer, digital 
readouts for counters, several counters, prescaler, 
microwavemeter, etc. 252 pages. S5.95. 



HOBBY COMPUTERS 
ARE HERE 
If you (or a friend) 
want to come up to 
speed on how com¬ 
puters work < .. hard¬ 
ware and software . . . 
this is an excellent 
book. It starts with the 
fundamentals and 
explains the circuits, 
the basics of program¬ 
ming, along with a 
couple TVT construc¬ 
tion projects, ASCII* 
Baudot, etc. This book 
has the highest recom¬ 
mendations as a teach¬ 
ing aid for newcomers. 
S-L95 


THE NEW 
COMPUTERS 

This book hikes 
over where the previous 
book leaves off. This. 
Like the other, is a col¬ 
lection of reprints from 
recent issues of 73 
Magazine (you've been 
missing a lot of very 
valuable data). This is 
one of the easiest ways 
to really understand 
how micros work and 
how to use them. Writ¬ 
ten entirely by hobby¬ 
ists (prepubli cation 
offer), $4,95 





NOVICE 
STUDY GUIDE 
This is the most 
complete Novice study 
guide available. It is 
brand new. This is not 
only invaluable for any¬ 
one wanting to get 
started in amateur 
radio, but also it is 
about the only really 
simple book on the 
fundamentals of elec¬ 
tricity and electronics. 
And without your 
fundamentals down 
pat, how can you go on 
to reallv understand 
ami work with com¬ 
puters? First things 
first, $4.95 

general class 

STUDY GUIDE 
This book takes 
over on theory where 
the Novice book leaves 
off. You’ll need to 
know the electronic 
theory in this to work 
with computers and 
you'll not find an easier 
place to get the infor¬ 
mation, ll will also 
make getting your Tech 
or General license a 
breeze . . , then you can 
get on the ham repeat¬ 
ers and interconnect 
your micro with others. 
$5.95 


i f 101 GAMES IN BASIC 

r f p — . Okay so once you get your computer up and 

\ running in B ASIC, then what? Then you need 

^“fc&isfvnr Some programs in BASIC, that's what. This book 

has lOl games for you, from very simple to real 
mE}' f. * buggers. You ^et the games, a description of the 

‘ ■ i games, the listing to put in your computer and a 

©k . sample run to show you how they work. $7.50 pp. 




S5TV HANDBOOK 

This excellent book tdlsall about it, from 
its history and basics to the present state of 
the art techniques. Contains chapters on 
circuits, monitors, cameras, color SSTV, test 
equipment and much more. 

Hardbound S7 Sofihound $5 


A 

i Slow 

SCAN 

TELEVISION 
HANDBOOK 


TTL COOKBOOK 

by Donald Lancaster, Explains what TTL is. how it 
warks r and how to use it. Discusses practical 
applications, such as a digital counter and display 
system, events counter, electronic stopwatch, 
digital voltmeter, and a digital tachometer. 336 
pages: 5% x BY,; softbound. $8,95 
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non-ham readers of 73. The barrage of computer articles in the 
magazine during the last year (over 300 pages of articles on hobby 
computers ... how many other magazines can claim that much?) has 


not entirely escaped the eyes of all computerists. 


Yes, 73 certainly does cover the 25 or so hobbies which are classed 
together as amateur radio . . . radioteletype (HTTY), slow scan 
television (SSTV), DXing (contacting foreign countries), FAX (facsim¬ 
ile transmission), FM and repeaters, satellite use, moonbouncing, 
contests, experimenting, home construction, and even rag chewing. 

There are articles on building and using test equipment, on timers, 
weather satellite systems, wind speed measuring, and hundreds of other 
related and unrelated subjects. 

73 is the largest of the ham magazines.. . the January 1977 issue ran 
55 articles and was over 200 pages. Add to all of that the irreverence of 
Wayne Green and his editorials and you have a magazine that most 
readers read from cover to cover every month ... no matter how many 
other magazines they get. 

- Do you really want to continue to miss all those computer articles7 
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